开发者

Quick and easy jQuery scroll question

开发者 https://www.devze.com 2023-03-11 01:33 出处:网络
I\'m developing a website that adds certain classes to bo开发者_如何学JAVAdy when the user reaches certain parts in the page, etc. As a result, I have to bind a function to the scroll event.

I'm developing a website that adds certain classes to bo开发者_如何学JAVAdy when the user reaches certain parts in the page, etc. As a result, I have to bind a function to the scroll event.

Is it better to cache the scrollTop() like this (short example, the actual function is longer):

scrollcheck: function() {

    var top = main.documentquery.scrollTop();

    if(top > 60) {stuff}
    if(top > 220) {more stuff}

Or just use main.documentquery.scrollTop() in all instances?

(documentquery is $(document), I remember caching that being good, but I'm not sure about scrollTop())


Yes, it's better to cache it, but it's also better to throttle the calls to this function. That will probably make a bigger performance impact. In particular, I would use a timeout pattern along these lines:

(function() {
    var _timeout = null;
    function onScrollHandler() {
        if (_timeout) {
            clearTimeout(_timeout);
        }
        _timeout = setTimeout(function() {
            _timeout = null;
            realScrollcheck();
        }, 500);
    }
    $(window).scroll(onScrollHandler);
 })();

There'll be a half-second delay after the last scroll for your function (called realScrollcheck here) to run, but in 99% of cases that's acceptable. Adjust the timeout at your leisure. :-)


Yes. It is better to store the value instead of calling it each time.

0

精彩评论

暂无评论...
验证码 换一张
取 消