注意分离:

  • 通过将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和浏览器模式)的更多相关文章

  1. javascript优化--14模式2(DOM和浏览器模式)

    远程脚本 XMLHttpRequest JSONP 和XHR不同,它不受同域的限制: JSONP请求的可以是任意的文档: 请求的URL通常格式为http://example.js?calback=Ca ...

  2. 文档类型DTD,DOCTYPE和浏览器模式

    出处:http://blog.csdn.net/freshlover/article/details/11616563 浏览器从服务端获取网页后会根据文档的DOCTYPE定义显示网页,如果文档正确定义 ...

  3. 【IE】浏览器模式与文档模式 及其开发中处理方式

    原文:http://blog.csdn.net/neo_liu0000/article/details/7589731 什么是浏览器模式和文本模式? 经常使用IE开发者工具的同学,肯定见过浏览器模式和 ...

  4. IE8"开发人员工具"使用详解下(浏览器模式、文本模式、JavaScript调试、探查器)

    来源: http://www.cnblogs.com/JustinYoung/archive/2009/04/03/kaifarenyuangongju2.html 在上一篇文章IE8“开发人员工具” ...

  5. DOM,浏览器,javascript,html之间的关系

    来源于:https://github.com/hucheng91/myBlog/blob/master/web/dom/dom.md DOM定义 DOM可以以一种独立于平台和语言的方式访问和修改一个文 ...

  6. javascript优化--07模式(对象)02

    沙箱模式: 解决空间命名模式的几个缺点: 命名空间模式中无法同时使用一个应用程序或库的两个版本运行在同一个页面中,因为两者需要相同的全局符号: 以点分割,需要输入更长的字符,解析时间也更长: 全局构造 ...

  7. <JavaScript>“浏览器模式”和“文档模式”之间的区别

    只有IE浏览器中才会有“浏览器模式”和“文档模式”,兼容性视图涉及两个重要的功能便是“浏览器模式[browser mode]”和“文档模式[document mode]”,在IE8/IE9中按F12键 ...

  8. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  9. 《高性能javascript》 领悟随笔之-------DOM编程篇

    <高性能javascript> 领悟随笔之-------DOM编程篇一 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

随机推荐

  1. Java EE学习——Quartz的Cron表达式

    经历过低谷后,还是要好好学习,越失落会越来越落后. 今天写一下Cron表达式的用法,虽然是之前自己写的,也过了挺长一段时间,这次就拿出来作为回顾吧. Cron表达式是Quartz的精髓(个人觉得),比 ...

  2. 2000多万个微信号被封全面禁止"集赞" 微信雷霆行动这次玩真的

    微信雷霆行动自年初启动了打击网络黑色产业链以来,微信累计封停了2000万个招嫖账号,3万个假货公众账号,切实保护用户利益.你曾经中过招吗?Yes or No?说说你的看法吧. 同时,微信从9日起开始升 ...

  3. Python 常用函数大体分类

    ==================系统库函数================ 字符串函数 举例数学函数 import math val=math.sin(3.14/6) val=math.sin(m ...

  4. Mysql性能监控

    show processlist; show global variables like 'max_allowed_packet'; // QPS计算(每秒查询数)show global status ...

  5. MSSQL复习

    1.用户角色: 登录名就相当于一个用户 角色相当于把你的操作权限分组了 2.数据系统结构(略) 网络连接接口 关系引擎 存储引擎 内存 3.数据库的结构 数据库 架构 对象(在Sql server中将 ...

  6. Android Activity模拟dialog

    Android项目中很多地方,都会弹出一个弹出框.类似于自己定义的alertDialog,比如微信的退出提示,但由于Dialog的限制,可能不能很完美的实现你的想要的功能,所有研究发现他们这种实现其实 ...

  7. SQL注入自学[第二学:注入环境的简单突破]

    /* 原文出处:珍惜少年时 留给原创一个ZBD机会. 加号即空格 */ 00x1 判断是否含有注入 http://127.0.0.1/1.php?id=3 and 1=1-- 返回正确的页面. htt ...

  8. ZeroMQ之Push与Pull (Java)

    本系列文章均转自:http://blog.csdn.net/kobejayandy/article/details/20163431 在ZeroMQ中并没有绝对的服务端与客户端之分,所有的数据接收与发 ...

  9. 推荐一个linux下的web压力测试工具神器webbench

    推荐一个linux下的web压力测试工具神器webbench2014-04-30 09:35:29   来源:   评论:0 点击:880 用多了apache的ab工具之后你就会发现ab存在很多问题, ...

  10. 57. 数对之差的最大值:4种方法详解与总结[maximum difference of array]

    [本文链接] http://www.cnblogs.com/hellogiser/p/maximum-difference-of-array.html [题目] 在数组中,数字减去它右边的数字得到一个 ...