标签:mouseover 加载 bsp 过程 文档碎片 网页 over 属性 模板
一.什么是渲染数据
就是HTML中要显示的数据是通过js来实现的而不是直接在HTML中输入数据,这个过程叫做数据渲染
二.渲染数据的方式
案例分析:
1.字符串拼接(最为常用的方式)
优点:只进行了一次Dom回流
缺点:原有dom的事件都会丢失
原因:就在与innerHTML这个属性,这个属性是返回或设置Dom中的内容,以字符串形式返回,拼接完之后是string类型,而onmouse这些属性是Dom元素对象身上的,所以这些onmouse系列的属性就丢失了。
2.dom循环
优点:原有的dom身上的事件不会丢失,不影响其他dom
缺点:dom回流次数过多,严重影响网页性能。
3.模板(本质与字符串相同)
4.文档碎片
优点: 既不影响原有dom的属性,也只回流一次。
Dom回流
每当对dom元素进行增删改的时候,浏览器就会重新加载一个,把新的结果渲染出来。
无论上面的四种方法,新增的li没有onmouseover事件,如果保证新增的li也拥有添加的事件。用dom遍历添加事件是不行的,用事件委托
标签:mouseover 加载 bsp 过程 文档碎片 网页 over 属性 模板
原文地址:https://www.cnblogs.com/Shinigami/p/10530939.html