课程咨询 :0551-65959799

合肥web前端培训

合肥web培训 > 达内新闻 > JavaScript要从哪些方面提升性能?
  • JavaScript要从哪些方面提升性能?

    发布:合肥web培训      来源:达内新闻      时间:2016-05-20

  • 合肥达内web培训专家详细的说一下JavaScript提升性能,要从哪些方面来着手。

    一、针对js文件的加载位置

    在HTML文件中,标签是可以加在区域和区域的。这里鉴于JavaScript执行和UI渲染的单线程原因,如果js文件载入会阻塞后面对于页面的解析过程,页面会等到js文件完全加载并运行后才继续执行该做的操作。那么问题就来了,这样可能会出现页面空白or卡顿现象。达内web培训专家认为,前端工程师不仅要实现需求,还要提供优质的用户体验。对此,有如下两个方法可以解决问题:

    1.  如果js文件没有特殊要求指明需要在页面渲染之前载入及编译完成的,那么选择将js文件放到 标签前,css文件放到head区域。这样做就能先让用户看到有布局的页面而不是空白页了,如果数据要通过js请求加载进来,我们可以对数据的加载做排序,急需呈现的接口放前面执行,其他的可以延后执行,同时做个简单的载入动画or提示。

    2.  如果这些js文件有指明需要先执行了,才能更好的展示页面内容,那么就在第一个js或者页面上先放个载入小动画,可以一些有趣的或者萌萌的动画场景。这样也可以避免用户等待的无聊,提升用户体验。

    最终推荐:将js尽可能的放到标签前面加载,以提升用户体验。

    二、针对js文件的合并

    我们可能会将不同功能的代码块分别放置在不同的js文件中,以便于开发过程中团队合作写代码会更加方便,毕竟只需要找对应文件夹或文件而不是在一个很长的文件中找一个方法。这确实是会提高团队开发效率及新人加入后的更容易进行二次开发及维护。那么针对页面性能,这个问题怎么办?

    下载1个100KB的文件比下载4个25KB的文件要快,而开发过程中区分开各个文件又有很大的好处,那么开发之后再合并就好了。

    三、更快速的数据访问

    对于浏览器来说,一个标识符所处的位置越深,去读写他的速度也就越慢。

    如果我们需要在当前函数内多次用到一个变量值,那么我们可以用一个局部变量先将其存储起来,案例如下:


    //修改前
      function showLi(){
          var i = 0;
          for(;i<document.getElementsByTagName("li").length;i++){    //一次访问document
              console.log(i,document.getElementsByTagName("li")[i]);  //三次访问document
          };
      };
      //修改后
      function showLi(){
          var li_s = document.getElementsByTagName("li");  //一次访问document
          var i = 0;
          for(;i<li_s.length;i++){
              console.log(i,li_s[i]);  //三次访问局部变量li_s
          };
      };


    四、DOM操作的优化

    众所周知的,DOM操作远比javascript的执行耗性能,虽然我们避免不了对DOM进行操作,但我们可以尽量去减少该操作对性能的消耗。

    让我们通过代码解释这个问题:

    function innerLi_s(){
          var i = 0;
          for(;i<20;i++){
              document.getElementById("Num").innerHTML="A"; //进行了20次循环,每次又有2次DOM元素访问:一次读取innerHTML的值,一次写入值
          };
      };

    针对以上方法进行一次改写:

    function innerLi_s(){
          var content ="";
          var i = 0;
          for(;i<20;i++){
              content += "A";  //这里只对js的变量循环了20次
          };
          document.getElementById("Num").innerHTML += content;  //这里值进行了一次DOM操作,又分2次DOM访问:一次读取innerHTML的值,一次写入值
      };

    五、减少Dom的重绘重排版

    元素布局的改变或内容的增删改或者浏览器窗口尺寸改变都将会导致重排,而字体颜色或者背景色的修改则将导致重绘。

    对于类似以下代码的操作,据说现代浏览器将其优化成1次重排版:

    //修改前
      var el = document.getElementById("div");
      el.style.borderLeft = "1px"; //1次重排版
      el.style.borderRight = "2px"; //又1次重排版
      el.style.padding = "5px"; //还有1次重排版
      //修改后
      var el = document.getElementById("div");
      el.style.cssText = "border-left:1px;border-right:2px;padding:5px"; //1次重排版


    针对多重操作,以下三种方法也可以减少重排版和重绘的次数:

    1.Dom先隐藏,操作后再显示 2次重排 (临时的display:none)

    2.document.createDocumentFragment() 创建文档片段处理,操作后追加到页面 1次重排

    3.var newDOM = oldDOM.cloneNode(true)创建Dom副本,修改副本后oldDOM.parentNode.replaceChild(newDOM,oldDOM)覆盖原DOM 2次重排

    六、循环的优化

    普遍都知道的写法,简单说一下

    //修改前
      var i = 0;
      for(;i<arr.lengthli++){  //每次循环都需要获取数组arr的length
          console.log(arr[i]);
      }
      //修改后
      var i = 0;
      var len = arr.length;  //获取一次数组arr的length
      for(;i<len;i++){
          console.log(arr[i]);
      }
      //or
      var i = arr.length;;
      for(;i;i--){
          console.log(arr[i]);
      }

    七、合理利用二进制

    如:对2取模,则偶数最低位是0,奇数最低位是0,与1进行位与操作的结果是0,奇数的最低位是1,与1进行位与操作的结果是1。

    代码如下:

     .odd{color:red}
      .even{color:yellow}

    <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
            <li>6</li>
     </ul>

    var i = 0;
      var lis = document.getElementsByTagName("li");
      var len = lis.length;
      for(;i<len;i++){
          if(i&1){
              lis[i].className = "even";
          } else{
              lis[i].className = "odd";
          }
      };

    推荐文章

上一篇:web开发者和设计师必备的20个CSS工具

下一篇:CSS技巧中的:before和:after

最新开班日期  |  更多

WEB零基础周末班

WEB零基础周末班

开班日期:4-28

WEB前端业余班

WEB前端业余班

开班日期:4-28

WEB零基础全日制班

WEB零基础全日制班

开班日期:4-28

WEB前端就业班

WEB前端就业班

开班日期:4-28

  • 地址:合肥市蜀山区肥西路66号汇金大厦21楼
  • 课程培训电话:0551-65959799     全国服务监督电话:400-111-8989
  • 服务邮箱 ts@tedu.cn
  • 2001-2016 达内时代科技集团有限公司 版权所有 京ICP证8000853号-56