Sometimes in my application there are many elements loading so I want to show the typical AJAX spinner above the control (or DOM node) with it disabled.
What is the easiest/best way to do that?
Ideally I would like to:
$("#myelement").loading();
$("#myelement").finishloading();
Or even better being able to do AJAX requests directly with the element:
$("#myelement").post(url, params, myfunction);
Being #myelement a regular node or form input.
Since you’re already using jQuery, you may want to look into BlockUI in conjunction with Darin Dimitrov’s answer. I haven’t used it yet myself as I just came across this today, but it looks decent.
If you’re writing a semi-large-ish application and anticipate making many AJAX calls from different places in your code, I would suggest that you either add a layer of abstraction over
$.ajax, or create a helper function to avoid having boiler plate for your UI indicator all over the place. This will help you out a lot should you ever need to change your indicator.Abstraction method
Helper method
Also, I wouldn’t suggest overwriting the
$.ajaxmethod itself.