博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2015第11周一
阅读量:6212 次
发布时间:2019-06-21

本文共 777 字,大约阅读时间需要 2 分钟。

今天写了近一天代码,感觉比较充实,但由于解决的大部分都是自己知道或简单尝试就能做好的事,就没什么成就感,但提前定下目标,果断按计划执行总是没错。 减少重绘,提高性能: 1.避免在document上直接进行频繁的DOM操作,如果确实需要可以采用off-document的方式进行,具体的方法包括但不完全包括以下几种: (1). 先将元素从document中删除,完成修改后再把元素放回原来的位置 (2). 将元素的display设置为”none”,完成修改后再把display修改为原来的值 (3). 如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document 2.集中修改样式 (1). 尽可能少的修改元素style上的属性 (2). 尽量通过修改className来修改样式 (3). 通过cssText属性来设置样式值 3. 缓存Layout属性值 对于Layout属性中非引用类型的值(数字型),如果需要多次访问则可以在一次访问时先存储到局部变量中,之后都使用局部变量,这样可以避免每次读取属性时造成浏览器的渲染。 var width = el.offsetWidth; var scrollLeft = el.scrollLeft; 4.设置元素的position为absolute或fixed 在元素的position为static和relative时,元素处于DOM树结构当中,当对元素的某个操作需要重新渲染时,浏览器会渲染整个页面。将元素的position设置为absolute和fixed可以使元素从DOM树结构中脱离出来独立的存在,而浏览器在需要渲染时只需要渲染该元素以及位于该元素下方的元素,从而在某种程度上缩短浏览器渲染时间,这在当今越来越多的Javascript动画方面尤其值得考虑。

转载地址:http://bnsja.baihongyu.com/

你可能感兴趣的文章
Android ADB命令的使用
查看>>
Python全栈 Web(Flask框架、CRUD、聚合分组)
查看>>
【最佳实践】使用BYOK密钥加密OSS中对象
查看>>
Scrapy实战-爬取豆瓣漫画
查看>>
[剑指offer] 矩阵中的路径
查看>>
log4j2配置
查看>>
07.Java基础(泛型)
查看>>
自制操作系统Antz day11——实现shell(下)命令响应
查看>>
MyBatis 笔记
查看>>
常见浏览器User-Agent大全
查看>>
第七章:Redis 位图bitmap&基数统计HyperLogLog
查看>>
声优直播互动平台克拉克拉获1.2亿元融资,将布局虚拟偶像互动
查看>>
poj 1154 letters (dfs回溯)
查看>>
php缓冲区与header函数之间的秘密
查看>>
Xcode 10: Build input file double-conversion cannot be found
查看>>
润乾V5与springBoot集成
查看>>
2018-07-26雨
查看>>
新的 TLS 加密破坏攻击也会影响新的 TLS 1.3 协议
查看>>
情人节·送什么给你的程序员男友?
查看>>
玩转算法面试(一)
查看>>