window resize和scroll事件的基本优化思路
window resize和scroll事件的基本优化思路
发布时间:2016-12-30 来源:查字典编辑
摘要:同事在项目中使用scroll事件去加载数据,结果IE下悲剧了。给了一个简单优化方法,效果明显。只要用户改变窗口大小,会对内部一些元素大小重新...

同事在项目中使用scroll事件去加载数据,结果IE下悲剧了。给了一个简单优化方法,效果明显。

只要用户改变窗口大小,会对内部一些元素大小重新计算,可能导致整个页面重新渲染,最终导致大量消耗 CPU。比如调用 resize 方法,用户改变窗口大小时会不停的被触发, 低版本的IE 会可能陷入假死状态。window的scroll事件也是如此,鼠标滚动或拖动滚动条,就会不停的触发scroll事件,如果处理的东西多,低版本的IE也会陷入假死状态。

基本的优化思路:在一定的时间之内,只执行一次resize事件函数。

复制代码 代码如下:

var resizeTimer = null;

$(window).on('resize', function () {

if (resizeTimer) {

clearTimeout(resizeTimer)

}

resizeTimer = setTimeout(function(){

console.log("window resize");

}, 400);

}

);

scroll事件优化同理。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类