Why Is Telling Jquery To Click My Link Button Slowing My Page Down?
Solution 1:
Ugh, well, I found my issue. Because I was using updatepanels I had to wrap my jQuery code to include an add_endRequest
. That is, you have something to the effect of:
$(document).ready(function() {
//Some initial event/triggersvar prm = Sys.WebForms.PageRequestManager.getInstance();
prm.add_endRequest(function () {
//Copy of some initial event/triggers
});
});
Why do I use the endRequest you ask? Well, because updatepanels basically throw away all your events after an asynchronous postback because the HTML at that point (after an update) is rendered again and at that point all events associated with any control inside an update panel are wiped away. At this point of course document.ready()
does not run, so I have to resubscribe to these events inside of endRequest
. Enter my issue...
I had a huge brain fart where I basically took everything, literally everything inside document ready and copied it into endRequest
. In fact, if I remember correctly, I read articles which stated
Whatever you have in document ready simply copy paste into endRequest
That's fine, but you have to be careful here. I was throwing in events that were not wrapped around inside of an updatepanel into endRequest
. The result is disastrous...at least for me.
These events would be attached then multiple times..or based on the number of asynchronous postbacks made. In my case, as I was testing I mentioned after the 6th or 7th time performance starts degrading. Well, by that time my controls were being attached that many times to events. For instance, my .apply
button along with my dropdownlist
were both outside of my updatepanel
. But my jQuery code was attaching the change event of my dropdownlist
in both document ready
and endRequest
.
The result is initially it's pretty fast, because it's only in document ready
. But as I make asynchronous postbacks these events are being attached every time. For n tests I would have n attached events...in my case the test of 7 yields 7 on change event handlers!
Case in point, do not place any event handlers such as jQuery's on()
event for any controls that are NOT inside an update panel. Otherwise you will run into what I ran into which was poor performance as events are happening.
Post a Comment for "Why Is Telling Jquery To Click My Link Button Slowing My Page Down?"