首页 web前端 js教程 做好七件事帮你提升jQuery的性能_jquery

做好七件事帮你提升jQuery的性能_jquery

May 16, 2016 pm 05:01 PM
jquery 性能

1. Append Outside of Loops

凡是触及到DOM都是有代价的。如果你向DOM当中附加大量的元素,你会想一次性将它们全部附加进来,而不是分多次进行。当在循环当中附加元素就会产生一个常见的问题。

复制代码 代码如下:

$.each( myArray, function( i, item ) {
    var newListItem = "
  • " + item + "
  • ";
        $( "#ballers" ).append( newListItem );
    });

    一个常用的技巧是利用文档片段(document fragment)。在循环的每一次迭代当中,将元素附加到片段而不是DOM元素当中。当循环结束后,将片段附加到DOM元素当中即可。

    复制代码 代码如下:

    var frag = document.createDocumentFragment();

    $.each( myArray, function( i, item ) {

        var newListItem = document.createElement( "li" );
        var itemText = document.createTextNode( item );

        newListItem.appendChild( itemText );

        frag.appendChild( newListItem );

    });

    $( "#ballers" )[ 0 ].appendChild( frag );

    另一个简单的技巧是在循环的每次迭代当中,持续构建一个字符串。当循环结束后,将DOM元素的HTML设置成该字符串。

    复制代码 代码如下:

    var myHtml = "";

    $.each( myArray, function( i, item ) {

        myHtml += "

  • " + item + "
  • ";

    });

    $( "#ballers" ).html( myHtml );

    当然还有其它一些技巧可以供你尝试。一个名为 jsperf 的站点为测试这些性能提供了一条好的出路。该网站允许你使用基准测试每一个技巧,并将其跨平台的性能测试结果可视化的展现出来。

    2. Cache Length During Loops

    在for循环当中,不要每次都访问数组的 length 属性;应当事先将其缓存起来。

    复制代码 代码如下:

    var myLength = myArray.length;

    for ( var i = 0; i

        // do stuff

    }

    3. Detach Elements to Work with Them

    操作DOM是缓慢的,因此你想尽可能减少对齐进行操作。jQuery在1.4版本当中引入了名为 detach() 的方法来帮助解决这一问题,它允许你在对元素进行操作时,将它们从DOM当中分离出来。

    复制代码 代码如下:

    var $table = $( "#myTable" );
    var $parent = $table.parent();

    $table.detach();

    // ... add lots and lots of rows to table

    $parent.append( $table );

    4. Don't Act on Absent Elements

    如果你正打算在一个空的选择器上运行大量的代码,jQuery并不会给予任何的提示 -- 它将会继续的执行,就像是没有发生任何的错误。必须由你来验证选择器包含了多少元素。

    复制代码 代码如下:

    // Bad: This runs three functions before it
    // realizes there's nothing in the selection
    $( "#nosuchthing" ).slideUp();

    // Better:
    var $mySelection = $( "#nosuchthing" );

    if ( $mySelection.length ) {

        $mySelection.slideUp();

    }

    // Best: Add a doOnce plugin.
    jQuery.fn.doOnce = function( func ) {

        this.length && func.apply( this );

        return this;

    }

    $( "li.cartitems" ).doOnce(function() {


        // make it ajax! \o/


    });

    本指南特别适用于那些当选择器不包含元素时还需要大量的开销的 jQuery UI 部件。

    5. Optimize Selectors

    选择器的优化和过去比起来并不是那么的重要,因为很多浏览器都实现了 document.querySelectorAll() 方法并且jQuery将选择器的负担转移到了浏览器上面。但是仍然有一些技巧需要铭记在心。

    基于ID的选择器

    以一个ID作为选择器的开始总是最好的。

    复制代码 代码如下:

     // Fast:
     $( "#container div.robotarm" );

     // Super-fast:
     $( "#container" ).find( "div.robotarm" );

    采用 .find() 方法的方式将更加的快速,因为第一个选择器已经过处理,而无需通过嘈杂的选择器引擎 -- ID-Only的选择器已使用 document.getElementById() 方法进行处理,之所以快速,是因为它是浏览器的原生方法。

    特异性

    尽量详细的描述选择器的右侧,对于左侧则应反其道而行之。

    复制代码 代码如下:

     // Unoptimized:
     $( "div.data .gonzalez" );

     // Optimized:
     $( ".data td.gonzalez" );

    尽量在选择器的最右侧使用 tag.class 的形式来描述选择器,而在左侧则尽量只使用 tag 或者 .class 。

    避免过度使用特异性

    复制代码 代码如下:

     $( ".data table.attendees td.gonzalez" );

     // Better: Drop the middle if possible.
     $( ".data td.gonzalez" );

    去讨好“DOM”总是有利于提升选择器的性能,因为选择器引擎在搜寻元素时无需进行太多的遍历。

    避免使用通用选择器

    如果一个选择器明确或暗示它能在不确定的范围内进行匹配将会大大影响性能。

    复制代码 代码如下:

     $( ".buttons > *" ); // Extremely expensive.
     $( ".buttons" ).children(); // Much better.

     $( ".category :radio" ); // Implied universal selection.
     $( ".category *:radio" ); // Same thing, explicit now.
     $( ".category input:radio" ); // Much better.
     Use Stylesheets for Changing CSS on Many Elements

    假如你使用 .css() 方法来改变超过20个元素的CSS,应当考虑为页面添加一个样式标签作为替代,这样做可以提升将近60%的速度。

    复制代码 代码如下:

     // Fine for up to 20 elements, slow after that:
     $( "a.swedberg" ).css( "color", "#0769ad" );

     // Much faster:
     $( "")
         .appendTo( "head" );
     Don't Treat jQuery as a Black Box

    把jQuery的源码当成文档,可以把它(http://bit.ly/jqsource)保存在你的收藏夹内,经常的查阅参考。

    本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    AI Hentai Generator

    AI Hentai Generator

    免费生成ai无尽的。

    热门文章

    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    2 周前 By 尊渡假赌尊渡假赌尊渡假赌
    仓库:如何复兴队友
    4 周前 By 尊渡假赌尊渡假赌尊渡假赌
    Hello Kitty Island冒险:如何获得巨型种子
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌

    热工具

    记事本++7.3.1

    记事本++7.3.1

    好用且免费的代码编辑器

    SublimeText3汉化版

    SublimeText3汉化版

    中文版,非常好用

    禅工作室 13.0.1

    禅工作室 13.0.1

    功能强大的PHP集成开发环境

    Dreamweaver CS6

    Dreamweaver CS6

    视觉化网页开发工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    Win11和Win10系统性能对比,究竟哪一个更胜一筹? Win11和Win10系统性能对比,究竟哪一个更胜一筹? Mar 27, 2024 pm 05:09 PM

    一直以来,Windows操作系统一直是人们在个人电脑上使用最为广泛的操作系统之一,而Windows10长期以来一直是微软公司的旗舰操作系统,直到最近微软推出了全新的Windows11系统。随着Windows11系统的推出,人们对于Windows10和Windows11系统之间的性能差异开始感兴趣,究竟两者之间哪一个更胜一筹呢?首先,让我们来看一下W

    Windows10与Windows11性能对比:哪个更胜一筹? Windows10与Windows11性能对比:哪个更胜一筹? Mar 28, 2024 am 09:00 AM

    Windows10与Windows11性能对比:哪个更胜一筹?随着科技的不断发展和进步,操作系统也在不断更新和升级。微软公司作为全球最大的操作系统开发商之一,其发布的Windows系列操作系统一直备受用户关注。在2021年,微软发布了Windows11操作系统,这引发了广泛的讨论和关注。那么,究竟Windows10与Windows11在性能方面有何不同,哪个

    麒麟8000处理器抗衡骁龙系列:谁能称王? 麒麟8000处理器抗衡骁龙系列:谁能称王? Mar 25, 2024 am 09:03 AM

    在移动互联网时代,智能手机已经成为人们日常生活中不可或缺的一部分。而智能手机的性能表现往往直接决定了用户体验的好坏。作为智能手机的“大脑”,处理器的性能表现尤为重要。在市场上,高通骁龙系列一直以来都是性能强劲、稳定可靠的代表,而最近华为也推出了自家研发的麒麟8000处理器,据称性能优异。对于普通用户来说,如何选择一款性能强劲的手机成为一个关键问题。今天我们就

    本地运行性能超越 OpenAI Text-Embedding-Ada-002 的 Embedding 服务,太方便了! 本地运行性能超越 OpenAI Text-Embedding-Ada-002 的 Embedding 服务,太方便了! Apr 15, 2024 am 09:01 AM

    Ollama是一款超级实用的工具,让你能够在本地轻松运行Llama2、Mistral、Gemma等开源模型。本文我将介绍如何使用Ollama实现对文本的向量化处理。如果你本地还没有安装Ollama,可以阅读这篇文章。本文我们将使用nomic-embed-text[2]模型。它是一种文本编码器,在短的上下文和长的上下文任务上,性能超越了OpenAItext-embedding-ada-002和text-embedding-3-small。启动nomic-embed-text服务当你已经成功安装好o

    PHP与Go语言对比:性能差异大 PHP与Go语言对比:性能差异大 Mar 26, 2024 am 10:48 AM

    PHP与Go语言是两种常用的编程语言,它们有着不同的特点和优势。其中,性能差异是大家普遍关注的一个问题。本文将从性能角度对比PHP和Go语言,并通过具体的代码示例来展示它们的性能差异。首先,让我们简要介绍一下PHP和Go语言的基本特点。PHP是一种脚本语言,最初设计用于Web开发,易学易用,广泛应用于Web开发领域。而Go语言是由Google开发的一种编译型

    不同Java框架的性能对比 不同Java框架的性能对比 Jun 05, 2024 pm 07:14 PM

    不同Java框架的性能对比:RESTAPI请求处理:Vert.x最佳,请求速率达SpringBoot2倍,Dropwizard3倍。数据库查询:SpringBoot的HibernateORM优于Vert.x及Dropwizard的ORM。缓存操作:Vert.x的Hazelcast客户机优于SpringBoot及Dropwizard的缓存机制。合适框架:根据应用需求选择,Vert.x适用于高性能Web服务,SpringBoot适用于数据密集型应用,Dropwizard适用于微服务架构。

    PHP 数组键值翻转:不同方法的性能对比分析 PHP 数组键值翻转:不同方法的性能对比分析 May 03, 2024 pm 09:03 PM

    PHP数组键值翻转方法性能对比表明:array_flip()函数在大型数组(超过100万个元素)下比for循环性能更优,耗时更短。手动翻转键值的for循环方法耗时相对较长。

    C++ 函数对程序性能有哪些影响? C++ 函数对程序性能有哪些影响? Apr 12, 2024 am 09:39 AM

    函数对C++程序性能的影响包括函数调用开销、局部变量和对象分配开销:函数调用开销:包括堆栈帧分配、参数传递和控制权转移,对小函数影响显着。局部变量和对象分配开销:大量局部变量或对象创建和销毁会导致堆栈溢出和性能下降。

    See all articles