javascript - Speeding up window resize function performance - Stack Overflow

I have some script similar to the following:var breakpoints = [0,240,480,960,9999],bpCount = breakpoint

I have some script similar to the following:

var breakpoints = [0,240,480,960,9999],
    bpCount = breakpoints.length,
    windowsize = 0;

window.onresize = function() {

    windowsize = document.body.clientWidth;

    for(var i=0; i<bpCount; i++) {
        if(windowsize >= breakpoints[i] && windowsize < breakpoints[i+1]) {
            doSomething(breakpoints[i]);
            break;
        }
    }    

};

However this seems to run pretty slowly, even in Chrome on a decent PC, and even when 'doSomething' is just performing a 'console.log', so I was just wondering if there was any better way of checking whether the screen size is between two values as it resizes?

Thanks

I have some script similar to the following:

var breakpoints = [0,240,480,960,9999],
    bpCount = breakpoints.length,
    windowsize = 0;

window.onresize = function() {

    windowsize = document.body.clientWidth;

    for(var i=0; i<bpCount; i++) {
        if(windowsize >= breakpoints[i] && windowsize < breakpoints[i+1]) {
            doSomething(breakpoints[i]);
            break;
        }
    }    

};

However this seems to run pretty slowly, even in Chrome on a decent PC, and even when 'doSomething' is just performing a 'console.log', so I was just wondering if there was any better way of checking whether the screen size is between two values as it resizes?

Thanks

Share Improve this question asked Nov 7, 2011 at 17:22 rwacarterrwacarter 2,0043 gold badges16 silver badges29 bronze badges 2
  • Maybe a little function throttling/debouncing can help, for example using the underscore library: documentcloud.github./underscore/#throttle – biziclop Commented Nov 7, 2011 at 17:25
  • Do you only want to doSomething() once for each range? – SLaks Commented Nov 7, 2011 at 17:25
Add a ment  | 

1 Answer 1

Reset to default 6

Don't poll for the size every single time. You're using way too much puting power.

Instead, make a timer and check for the size every so often (10 ms might be too fast):

var checkWindowSizeTimer;

function checkWindowSize() {
    var windowsize = document.body.clientWidth;

    if (windowsize >= breakpoints[i] && windowsize < breakpoints[i+1]) {
        doSomething(breakpoints[i]);
        clearInterval(checkWindowSizeTimer);
    }
}

window.onresize = function() {
  checkWindowSizeTimer = setInterval(checkWindowSize, 10);
}

When the window is resized past your bounds, the timer exits.

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1745671724a4639444.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信