发布网友 发布时间:2022-04-20 00:22
共2个回答
懂视网 时间:2022-04-20 04:44
获取某些属性。
当获取一些属性时,浏览器为取得正确的值也会触发重排。这样就使得浏览器的优化失效了。这些属性包括:offsetTop、offsetLeft、 offsetWidth、offsetHeight、scrollTop、scrollLeft、scrollWidth、scrollHeight、clientTop、clientLeft、clientWidth、clientHeight、getComputedStyle() (currentStyle in IE)。所以,在多次使用这些值时应进行缓存。
此外,改变元素的一些样式,调整浏览器窗口大小,滚动条出现等等也都将触发重排。
减少重排次数和重排影响范围
1、将多次改变样式属性的操作合并成一次操作。例如,
JS: var changep = document.getElementById(‘changep’); changep.style.color = ‘#093′; changep.style.background = ‘#eee'; changep.style.height = ‘200px'; 可以合并为: CSS: p.changep { background: #eee; color: #093; height: 200px; } JS: document.getElementById(‘changep’).className = ‘changep';
2、 将需要多次重排的元素,position属性设为absolute或fixed,这样此元素就脱离了文档流,它的变化不会影响到其他元素。例如有动画效果的元素就最好设置为绝对定位。
3、 在内存中多次操作节点,完成后再添加到文档中去。例如要异步获取表格数据,渲染到页面。可以先取得数据后在内存中构建整个表格的html片段,再一次性添加到文档中去,而不是循环添加每一行。
4、 由于display属性为none的元素不在渲染树中,对隐藏的元素操作不会引发其他元素的重排。如果要对一个元素进行复杂的操作时,可以先隐藏它,操作完成后再显示。这样只在隐藏和显示时触发2次重排。
5、 在需要经常取那些引起浏览器重排的属性值时,要缓存到变量
相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
S5让分层屏幕适配
h5实现多图片预览上传及点击可拖拽控件
热心网友 时间:2022-04-20 01:52
摘要您好,您的问题我已经看到了,正在整理答案,请您耐心等候一分钟咨询记录 · 回答于2021-11-14iQOO手机怎么使用重绘图标您好,您的问题我已经看到了,正在整理答案,请您耐心等候一分钟首先我们在手机上找到并打开“设置”功能。找到“桌面、锁屏与壁纸”选项,点击它。在“桌面、锁屏与壁纸”设置中,第一项就是桌面设置,点击进入。找到“动态图标”功能,他默认是关闭的。我们点击一下它,把功能打开即可。谢谢