zoukankan      html  css  js  c++  java
  • Juery 高性能编码

    现在jQuery已经出现在很多项目中,然而许多同学忽略了他的性能问题以及代码质量问题,
    下面是我对jQuery的一些性能方面的学习.

    转载http://www.cnblogs.com/xiyangbaixue/p/3951361.html

    选择器

    选择器是jQuery中的核心功能,选择同一个DOM元素我们可以使用不同的方法。但是哪一种是最快的呢?

    1. if possible, please use more id selector. id selector is used javascript method getElementById
      //bad
      ('#id selector') 
      //good('#id')

      caution: don't use tag to decorate id selector

    2. Before using class selector, you'd better add tag. that's is used javascript method getElementsByTagName
      //bad
      (.class)//good('tag.class')

      caution: class selector is the slower selector, use less

    3. if possible, right more detail
      //bad
      (tag.class.class)//good('.class tag.class')

    4. when you select children, you'd better use find. the best way that cache the parent.
      var parent = $('#parent');
      var children = parent.find('children');

    5. 最慢选择器:伪类选择器和属性选择器,新的浏览器增加了querySelector()和querySelectorAll()方法,可能会使这两类选择器性能提升

    6. 从父元素选择子元素

      • (child,parent)
        这种选择其实会执行$parent.find('child'),排名第二
      • (child,('parent'))
        这种选择会别转成$('parent').find('child'),排名第三
      • $('#parent child')
        这种选择适合选择多级子元素,排名第六
      • $('#parent > child')
        这种选择和上面的相同,排名第五
      • parent.children(child).sibling(),排名第四
      • $parent.find('child')
        这种选择会被转成getElementById,getElementByName,getElementByTagName等javascript原生语法,所以速度最快,排名第一
      总结:ID选择器是最快的选择器,建议多用。然后是标签选择器,其次是class选择器   

    函数

    1. 使用jQuery的内部函数data()来存储状态

    2. 尽量使用on方法来绑定事件,因为任何绑定方法都是最终使用on来实现的

    代码质量

      1. 不要在循环中直接操作 DOM:
        // 性能差
        $.each(myArray, function(i, item) {
        var newListItem = '

      2. '+item+'
      3. ';


    ('#contain').append(newListItem); 
     }); 
     // 性能好 
     var html = '';.each(myArray, function(i, item) {
    html += '

    • ' + item + '

    ';
    });
    $('#contain').html(myHtml);

    • 对数组循环时,缓存数组长度
      for(var i = 0, len = array.length; i < len; i++) {

      }           
    • 尽量少使用匿名函数,最好使用类封装
      var mo = {
      init: function() {

          }        
      };           
    • 缓存变量,DOM遍历最消耗性能,所以尽量将重用的元素缓存
      height = ('#element').height();('#element').css('height', height);
      // 好的做法
      element=('#element');
      height = element.height();element.css('height', height);

    • 尽量少使用全局变量
      ele=('#element');
      // 最好使用var
      var ele=('#element');

    • 简单的语句可以使用原生的javascript,因为jQuery最终执行的也是原生的

    • 使用链式写法,因为使用链式写法jQuery自动缓存每一步的结果,因此比非链式写法要快

    • 尽量少使用$.each进行循环,使用原生javascript的for和while来进行

    • jQuery大部分方法都有两种,例如:().each.each

      $().each是基于jQuery对象的,jQuery对象会占用很多资源,因为他包含很多属性和方法        
      $.each是基于jQuery方法的,不会占用太多资源,所以尽量使用这种方式   

    10.尽量使用.ajax,使.get(),.getJSON(),.post(),因为他们最终也是用的$.ajax()

    减少代码嵌套:

    减少代码嵌套,对于阅读和维护代码来时都是有益的,通过deffer我们可以减少代码的嵌套

          ***第一种:***        
            var request = function() {        
                var defer = $.Deferred();        
                $.ajax({url:'data/test.json'})        
                .done(function(data){        
                    defer.resolve(data);        
                });        
                return defer;        
            };     
    
            $.when(request())
            .then(function(data) {
                console.log(data);
            });        
    
          ***第二种:***        
            var request = function() {        
                return $.ajax({url:'data/test.json'});        
            };
    
            $.when(request())
            .then(function(data) {
                console.log(data);
            });        
    
          ***第三种:***        
            $.when($.ajax(url:'data/test.json'))
            .then(function(data) {
                console.log(data);
            });  
  • 相关阅读:
    PHP 支付类库, cURL开源HTTP类库
    sublime text3 批量查找替换文件夹或项目中的字符
    php 腾讯云 对象存储V5版本 获取返回的上传文件的链接方法
    Redis Desktop Manager 利用ssh连接 Redis
    一键PHP/JAVA安装工具 OneinStack
    函数之局部变量和使用global语句
    函数之定义形参
    函数之定义函数
    大数据入门第二十天——scala入门(二)scala基础02
    大数据入门第二十天——scala入门(二)scala基础01
  • 原文地址:https://www.cnblogs.com/zzhui/p/5048413.html
Copyright © 2011-2022 走看看