javascript优化--13模式1(DOM和浏览器模式)
注意分离:
- 通过将CSS关闭来测试页面是否仍然可用,内容是否依然可读;
- 将JavaScript关闭来测试页面仍然可以执行正常功能;所有连接是否正常工作;所有的表单是否可以正常工作;
- 不使用内联处理器(onclick之类)和内联样式属性,因为这些不属于内容层;
- 使用语义上有意义的HTML元素;
DOM脚本:
- DOM访问: //DOM访问的代价是昂贵的 ;
- 避免在循环中使用DOM访问;
- 在可能的情况下使用selector API; /尽可能使用id,getElementById是最便捷的查找方法;
- 在HTML容器中重复使用时,缓存重复的次数;
- 将DOM引用分配给局部变量,并使用这些局部变量;
- 例子:
for (var i = 0; i < 100; i += 1) {
document.getElementById('result').innerHTML += i + ' ,';
} //优化
var i, content = ' ';
for(i = 0; i < 100; i +=1) {
content += i + ' ,';
}
document.getElementById('result1').innerHTML += content; --------------------------------
var padding = document.getElementById('result').style.padding,
margin = document.getElementById('result').style.margin;
//优化
var style = document.getElementById('result').style,
padding = style.padding,
margin = style.margin; ----------------------------
//更好的获取节点 ,IE8以上
document.querySelector();
document.querySelectorAll();
- 操纵DOM:更新DOM会导致浏览器重新绘制屏幕;所以尽量减少更新DOM;当需要创建相对比较大的子树时,采用文档碎片;
- 创建文档时例子:
//反模式,在创建时立即添加节点
var p,t;
p = document.createElement('p');
t = document.createTextNode('first paragraph');
p.appendChild(t);
document.body.appendChild(p); p = document.createElement('p');
t = document.createTextNode('second paragraph');
p.appendChild(t);
document.body.appendChild(p);
//优化,
var p ,t , frag;
frag = document.createDocumentFragment(); p = document.createElement('p');
t = document.createTextNode('first paragraph');
p.appendChild(t);
frag.appendChild(p); p = document.createElement('p');
t = document.createTextNode('second paragraph');
p.appendChild(t);
frag.appendChild(p); document.body.appendChild(frag); - 更新文档时例子:
//cloneNode
var oldnode = document.getElementById('result');
clone = oldnode.cloneNode(true);
//处理克隆对象
var t = document.createTextNode('new text');
clone.appendChild(t);
//replaceChild
oldnode.parentNode.replaceChild(clone, oldnode);
- 创建文档时例子:
事件:
- 事件处理:
- 最简单地使用事件函数;//不要使用内联
- 最好使用监听器;
- 事件授权:利用事件冒泡,可以减少事件监听器的数量
<div id='click-wrap'>
<button>Click me:0</button>
<button>Click me too:0</button>
<button>Click me three:0</button>
</div> var target = document.getElementById('click-wrap');
target.addEventListener('click',function(e){
var src = e.target;
if(src.nodeName.toLowerCase() !== 'button') return;
alert(0);
},false);//注意以上实际情况中使用要考虑浏览器的兼容性;
长期运行脚本
//js没有线程,用其他方法模拟
- 使用setTimeout;
- 使用web workers (html5)
var ww = new Worker("test.js");
ww.onmessage = function(event) {
document.body.innerHTML += "<p>message :" + event.data + "</p>";
}
//test.js
var end = 1e8, tmp = 1;
postMessage("hello");
//Web Workers做了1e8次简单的计算
while(end) {
end -= 1;
tmp += end;
if(end === 5e7) {
postMessage('halfway there, `tmp` is now ' + tmp);
}
}
postMessage("all done");
javascript优化--13模式1(DOM和浏览器模式)的更多相关文章
- javascript优化--14模式2(DOM和浏览器模式)
远程脚本 XMLHttpRequest JSONP 和XHR不同,它不受同域的限制: JSONP请求的可以是任意的文档: 请求的URL通常格式为http://example.js?calback=Ca ...
- 文档类型DTD,DOCTYPE和浏览器模式
出处:http://blog.csdn.net/freshlover/article/details/11616563 浏览器从服务端获取网页后会根据文档的DOCTYPE定义显示网页,如果文档正确定义 ...
- 【IE】浏览器模式与文档模式 及其开发中处理方式
原文:http://blog.csdn.net/neo_liu0000/article/details/7589731 什么是浏览器模式和文本模式? 经常使用IE开发者工具的同学,肯定见过浏览器模式和 ...
- IE8"开发人员工具"使用详解下(浏览器模式、文本模式、JavaScript调试、探查器)
来源: http://www.cnblogs.com/JustinYoung/archive/2009/04/03/kaifarenyuangongju2.html 在上一篇文章IE8“开发人员工具” ...
- DOM,浏览器,javascript,html之间的关系
来源于:https://github.com/hucheng91/myBlog/blob/master/web/dom/dom.md DOM定义 DOM可以以一种独立于平台和语言的方式访问和修改一个文 ...
- javascript优化--07模式(对象)02
沙箱模式: 解决空间命名模式的几个缺点: 命名空间模式中无法同时使用一个应用程序或库的两个版本运行在同一个页面中,因为两者需要相同的全局符号: 以点分割,需要输入更长的字符,解析时间也更长: 全局构造 ...
- <JavaScript>“浏览器模式”和“文档模式”之间的区别
只有IE浏览器中才会有“浏览器模式”和“文档模式”,兼容性视图涉及两个重要的功能便是“浏览器模式[browser mode]”和“文档模式[document mode]”,在IE8/IE9中按F12键 ...
- 前端网络、JavaScript优化以及开发小技巧
一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...
- 《高性能javascript》 领悟随笔之-------DOM编程篇
<高性能javascript> 领悟随笔之-------DOM编程篇一 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...
随机推荐
- [整理]Code::Blocks使用遇到的问题
在使用其编写C小程序的过程总会遇到些问题,特整理如下: 1.无法调试 注意的是项目所在的文件路径不能包含中文. 2.头文件接口函数申明引用无效 查看头文件是否处于可编译状态,左侧项目文件列表里是文件名 ...
- PHP+MySQL无限级分类(非递归)
要实现无限级分类,递归一般是第一个也是最容易想到的,但是递归一般被认为占用资源的方法,所以很多系统是不考虑使用递归的 本文还是通过数据库的设计,用一句sql语句实现 数据库字段大概如下: 字段 说明 ...
- 小白科普之JavaScript的数组
一.与其他语言数据的比较 相同点:有序列表 不同点:js的数组的每一项可以保存任何类型的数据:数组的大小是可以动态调整的 二.数组创建的两种方法 1) var colors = new ...
- Bridge 使用
- 【转】使用genstring和NSLocalizedString实现App文本的本地化
原地址:http://www.cnblogs.com/U-tansuo/p/IOS_NSLocalizedString.html iOS提供了简便的方法来实现本地化,其中用的最多的就是NSLocali ...
- 将服务器上的myql数据库导入本地数据库
文章是从我的个人博客上粘贴过来的, 大家也可以访问 www.iwangzheng.com 首先登录到服务器上,进入文件夹,我们这边的是m-cms $mysqldump -uroot mos > ...
- Redis系列-远程连接redis并给redis加锁
假设两台redis服务器,ip分别为:192.168.1.101和192.168.1.103,如何在101上通过redis-cli访问103上的redis呢?在远程连接103之前,先讲下redis-c ...
- PHP session的实现原理
PHP SESSION原理 我们知道,session是在服务器端保持用户会话数据的一种方法,对应的cookie是在客户端保持用户数据.HTTP协议是一种无状态协议,服务器响应完之后就失去了与浏览器的联 ...
- 使用git如何批量对文件进行rm操作
git add -A 它会把我们未通过 git rm 删除的文件全部stage 转自: http://segmentfault.com/q/1010000000095373
- 【Python】python代码如何调试?
Python 程序如何高效地调试? 现在我在debug python程序就只是简单在有可能错误的地方print出来看一下,不知道python有没像c++的一些IDE一样有单步调试这类的工具?或者说各位 ...