今天我们为大家介绍一下web前端中涉及到的回流和重绘的概念,先来看一下官方给出的定义:

      回流(reflow):对于DOM结构中的各个元素都有自己的盒子模型,这些都需要浏览器根据各种样式(浏览器的、开发人员定义的等)来计算并根据计算结果将元素放到它该出现的位置,这个过程称之为reflow ;

      重绘(repaint):当各种盒子的位置、大小以及其他属性,例如颜色、字体大小等都确定下来后,浏览器于是便把这些元素都按照各自的特性绘制了一遍,于是页面的内容出现了,这个过程称之为repaint。

      其实简单的说:

      回流(reflow)就是元素的位置发生了改变(不管是添加、删除元素,还是元素尺寸改变),会触发回流。比如,这里有2个p标签,我们想在两个p标签之间插入另外一个p标签

      这个时候老大还是老大,插入一个新老二之后,原来的老二变成了老三,位置发生了改变会触发回流。

      那么重绘(repaint)简单的说,元素位置不会发生改变,视觉效果会有所改变。

      元素的位置没有发生改变,只有文字颜色做了修改,这个时候就发生了重绘。知道了回流和重绘,我们在做项目的过程中,要尽量避免,这样可以使我们写出高性能的DOM。例如:我们在给元素添加样式修饰时,避免一条条更改

      可以将修饰放入一个class名中,做一次class名插入

      还有我们要循环插入很多DOM元素时,可以使用documentFragment

希望本文的分享能帮到学习web前端的小伙伴们。

本文来自千锋教育,转载请注明出处。

©著作权归作者所有:来自51CTO博客作者戏精程序媛的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 教你用Python爬虫自制有道翻译词典
  2. VsCode常用设置,新手必备!
  3. web前端开发都用什么软件?
  4. 前端inline元素间隙问题解决办法
  5. 态路小课堂丨QSFP-DD封装模式光模块接口类型:LC/MPO12/MPO16/MPO2
  6. 图解 Java 中的数据结构及原理,不懂的也能看清楚
  7. 价值200万的小米LOGO给UI设计师带来了什么?
  8. 动态记忆网络:向通用NLP更近一步
  9. 一文讲解回流和重绘

随机推荐

  1. Java:创建程序以查找圆柱体的表面积和体积
  2. 企业分布式微服务云SpringCloud SpringBo
  3. 初用idea建立javaweb遇到的问题与心得
  4. Java递归实现算24
  5. 如何在Javascript中解析URL查询参数?(复
  6. JAVA 实现tail -f 日志文件监控功能
  7. Servlet也是一个Java类.为什么我不可以将
  8. 单例模式中的懒汉模式和饿汉模式
  9. tomcat启动web项目时候突然卡住
  10. 导致org.hibernate创建记录。MappingExce