【DOM】1.DOM优化
1.JS include :DOM BOM ECMA
2.Browser 分别独立实现dom & JS
as if two isolated islands
3.JS操作DOM
from the island to the other one
4.DOM性能
The bridges between islands,charge everytime passing by
尽量减少过桥次数
5.innerHTML vs dom method
webkit:eg, chrome, dom>innerHTML
others:dom<innerHTML
二、减少DOM操作
1.节点克隆
cloneNode(true)里面也复制,性能较好
2.访问元素集合
尽量使用局部变量
var doc=document
3.元素节点
尽量 用只获取元素的节点办法
childNode->元素节点、文本节点
children->元素节点
firstChild
firstElementChild
4.选择器API
利用querySelector、querySelectorAll\
var oul=document.getElementById('ul1');
var ali=oul.getElementsByTagName('li');
var ali=document.querySelectorAll('#ul1 li');
三、DOM与浏览器的关系
1、重排:改变页面内容
2、重绘:浏览器显示内容
(以上两个最耗性能咯)
3、添加顺序:尽量在appendChild前添加操作
4、合并dom操作:利用CSSText
5、缓存布局信息
6、文档碎片:createDocumentFragment()
四、DOM与事件
事件委托
专门开课
五、DOM与前端模板
能更好的对逻辑和视图分离,MVC架构的基础
jquery.teml()
【DOM】1.DOM优化的更多相关文章
- DOM解析和优化
		
DOM解析 1. css不会阻塞DOM解析(DOM Tree),但会阻塞DOM渲染(css Tree + DOM Tree -> render Tree )2. JS阻塞DOM解析,但浏览器会预 ...
 - JS对DOM的操作优化法则
		
html页面显示过程 解析HTML,并生成一棵DOM tree 解析各种样式并结合DOM tree生成一棵Render tree 对Render tree的各个节点计算布局信息,比如box的位置与尺寸 ...
 - Virtual DOM 虚拟DOM的理解(转)
		
作者:戴嘉华 转载请注明出处并保留原文链接( #13 )和作者信息. 目录: 1 前言 2 对前端应用状态管理思考 3 Virtual DOM 算法 4 算法实现 4.1 步骤一:用JS对象模拟DOM ...
 - React v16-alpha 从virtual dom 到 dom 源码简读
		
一.物料准备 1.克隆react源码, github 地址:https://github.com/facebook/react.git 2.安装gulp 3.在react源码根目录下: $npm in ...
 - -_-#【Dom Ready / Dom Load】
		
Dom Ready和Dom Load DOM Ready 详解 javascript的domReady 域名解析 - 加载html - 加载js和css - Dom Ready - 加载图片等其他信息 ...
 - js 字符串转dom 和dom 转字符串
		
js 字符串转dom 和dom 转字符串 博客分类: JavaScript 前言: 在javascript里面动态创建标准dom对象一般使用: var obj = document.createE ...
 - javascript DOM和DOM操作的四种基本方法
		
在了解了javascript的语言特性后,javascript真正大放光彩的地方来了——这就是javascript DOM Javascript DOM DOM(Document Object Mod ...
 - 精讲 org.w3c.dom(java dom)解析XML文档
		
org.w3c.dom(java dom)解析XML文档 位于org.w3c.dom操作XML会比较简单,就是将XML看做是一颗树,DOM就是对这颗树的一个数据结构的描述,但对大型XML文件效果可能会 ...
 - 虚拟DOM    Vitural DOM Tree
		
提起Virtual DOM,总是给人一种高深莫测的感觉,大家都知道它比DOM快.那么Virtual DOM到底是何方神圣呢?在深入理解Virtual DOM之前,先让我们回顾一下DOM. 一.什么 ...
 - DOM & Shadow DOM & Virtual DOM
		
DOM & Shadow DOM & Virtual DOM What is the difference between Shadow DOM and Virtual DOM? ht ...
 
随机推荐
- js检测对象的类型
			
在JavaScript中,想要判断某个对象值属于哪种内置类型,最靠谱的做法就是通过Object.prototype.toString方法. 示例: var array=[1,2,3]; Object. ...
 - winform访问url传参有返回值
			
using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Net;usi ...
 - KafkaSpout的处理流程
			
基于0.93版本Storm 首先,如果自己写KafkaSpout,该怎么办?有哪些地方需要考虑呢 1. 得实现Storm指定的接口.这样Storm才能够使用它.那么需要实现什么接口?需要提供什么功能给 ...
 - linux下执行 ls,cat等一些命令报出 -bash: /bin/cat: Cannot allocate memory 有没解决的方法
			
环境变量配置出错了cd -- 进入用户目录vim .bash_profile删除以前PATH这一行,把下面的粘帖进去PATH=$PATH:$HOME/bin:/root:/root/snapshot/ ...
 - hdu 4664 Triangulation 博弈论
			
看到这题时,当时还不会做,也没搞懂sg函数,于是狠狠的钻研了下博弈论,渐渐的知道了sg函数…… 现在在来做这题就很容易了,1A 打表容易发现在80左右的时候就出现循环节了 代码如下: #include ...
 - linux usermod修改用户所在组方法
			
usermod 用户名 -g 组名 -g<群组> 修改用户所属的群组. -G<群组> 修改用户所属的附加群组.
 - [itint5]合并K个有序链表
			
merge sort,leet code里面曾经做过.但一开始没这么写,遍历来做,效率n*k了,用了merge sort后,变成logn*k. 用了dummy node.同时要注意size为0的情况. ...
 - *[topcoder]GooseTattarrattatDiv1
			
http://community.topcoder.com/stat?c=problem_statement&pm=12730&rd=15701 这道题有点意思.首先把字符串变成回文, ...
 - Move to Another Changelist
			
Move to Another Changelist 将选中的文件转移到其他的 Change list 中. Change list 是一个重要的概念,这里需要进行重点说明.很多时候,我们开发一个项目 ...
 - Layout Resource官方教程(4)<include>与<merge>
			
Re-using Layouts with <include/> THIS LESSON TEACHES YOU TO Create a Re-usable Layout Use the ...