When you use this technique, your user feels as fast as client app.
The conventional method
- Set onClick = 'update(this);' to element
- Post with update()
- Wait for callback function
- Update UI with callback function
→User has to wait for callback function.(S)he feels slow.
This technique
- Set onClick = 'update(this);' to element
- Before post with update(),update UI
- Wait for callback function
- If post is failed,reset UI and handle error with callback function
→User doesn't have to wait for callback function.(S)he feels fast.
#If app's updateing often fails and a user overlook errors and resetting UI, (s)he has discontent.
Best practice
Callback function works only for resetting UI and handling error so you can commonize it.
Note
The conventional method is popular method.Why?I think the reason is callback function is too convinient.
'Language defines thinking'--This is Sapir-Whorf hypothesis.I suggest that callback function defines programmer's thinking.
In Fuzzy system,for example SNS,Game, you might want to use this technique.
Especially in Game,fast response is essential.