window resize和scroll事件的基本优化思路


Posted in Javascript onApril 29, 2014

同事在项目中使用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 相关文章推荐
DEFER怎么用?
Jul 01 Javascript
发两个小东西,ASP/PHP 学习工具。 用JavaScript写的
Apr 12 Javascript
js导入导出excel(实例代码)
Nov 25 Javascript
使用js实现一个可编辑的select下拉列表
Feb 20 Javascript
JavaScript中textRange对象使用方法小结
Mar 24 Javascript
javascript实现五星评价代码(源码下载)
Aug 11 Javascript
AngularJS基于provider实现全局变量的读取和赋值方法
Jun 28 Javascript
AngularJS使用$http配置对象方式与服务端交互方法
Aug 13 Javascript
vsCode安装使用教程和插件安装方法
Aug 24 Javascript
微信小程序如何调用图片接口API并居中显示
Jun 29 Javascript
ES6 Symbol在对象中的作用实例分析
Jun 06 Javascript
基于JavaScript的数据结构队列动画实现示例解析
Aug 06 Javascript
js父窗口关闭时子窗口随之关闭完美解决方案
Apr 29 #Javascript
JS截取url中问号后面参数的值信息
Apr 29 #Javascript
javascript类型转换示例
Apr 29 #Javascript
常见浏览器多长时间会提示“脚本运行时间过长”总结
Apr 29 #Javascript
javascript中使用正则计算中文长度的例子
Apr 29 #Javascript
一个简单的Node.js异步操作管理器分享
Apr 29 #Javascript
IE浏览器中图片onload事件无效的解决方法
Apr 29 #Javascript
You might like
php学习之数据类型之间的转换代码
2011/05/29 PHP
php var_export与var_dump 输出的不同
2013/08/09 PHP
php 反斜杠处理函数addslashes()和stripslashes()实例详解
2016/12/25 PHP
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
2011/07/04 Javascript
js Array对象的扩展函数代码
2013/04/24 Javascript
jQuery往textarea中光标所在位置插入文本的方法
2015/06/26 Javascript
jquery中val()方法是从最后一个选项往前读取的
2015/09/06 Javascript
javascript实现禁止复制网页内容汇总
2015/12/30 Javascript
JavaScript 拖拽实例代码
2016/09/21 Javascript
vue-router 学习快速入门
2017/03/01 Javascript
微信小程序canvas实现刮刮乐效果
2018/07/09 Javascript
js实现延迟加载的几种方法详解
2019/01/19 Javascript
用 js 写一个 js 解释器过程详解
2019/08/02 Javascript
详解ECMAScript2019/ES10新属性
2019/12/06 Javascript
微信小程序之左右布局的实现代码
2019/12/13 Javascript
如何在vue项目中嵌入jsp页面的方法(2种)
2020/02/06 Javascript
五句话帮你轻松搞定js原型链
2020/12/09 Javascript
[51:30]OG vs LGD 2018国际邀请赛淘汰赛BO3 第二场 8.26
2018/08/30 DOTA
python编程-将Python程序转化为可执行程序[整理]
2007/04/09 Python
Python实现判断并移除列表指定位置元素的方法
2018/04/13 Python
python远程连接服务器MySQL数据库
2018/07/02 Python
Django stark组件使用及原理详解
2019/08/22 Python
Django1.11自带分页器paginator的使用方法
2019/10/31 Python
Python项目跨域问题解决方案
2020/06/22 Python
Python WebSocket长连接心跳与短连接的示例
2020/11/24 Python
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
2014/09/02 HTML / CSS
HTML5自定义属性前缀data-及dataset的使用方法(html5 新特性)
2017/08/24 HTML / CSS
英语专业学生个人求职信
2014/01/28 职场文书
运动会演讲稿
2014/05/07 职场文书
优秀家长事迹材料
2014/05/17 职场文书
教师求职信
2014/06/17 职场文书
党员干部群众路线个人整改措施
2014/09/18 职场文书
志愿者个人总结
2015/03/03 职场文书
一个都不能少观后感
2015/06/04 职场文书
超外差式晶体管收音机的组装与统调
2021/04/22 无线电
Python实现照片卡通化
2021/12/06 Python