Heim Web-Frontend js-Tutorial jquery提升性能最佳实践小结_jquery

jquery提升性能最佳实践小结_jquery

May 16, 2016 pm 06:14 PM
性能

将jquery对象缓存起来在
for循环中,不要每次都要访问数组的length属性,我们应该先将对象缓存进一个变量然后再操作,如下所示:

复制代码 代码如下:

var myLength = myArray.length;
for (var i = 0; i // 要做的事
}

在循环外使用append

进行DOM操作是有代价的,如果需要往DOM中添加大量元素,你应该一次批量完成,而不是一次一个。
复制代码 代码如下:

// 别这样
$.each(reallyLongArray, function(count, item) {
var newLI = '
  • ' + item + '
  • ';
    $('#ballers').append(newLI);
    });
    //较好的做法
    var frag = document.createDocumentFragment();
    $.each(reallyLongArray, function(count, item) {
    var newLI = '
  • ' + item + '
  • ';
    frag.appendChild(newLI[0]);
    });
    $('#ballers')[0].appendChild(frag);不要在each()里用$('#id')的选择器,会有多次遍历查找dom元素,效率极低用document.createDocumentFragment()来减少页面的DOM结构改变的次数、刷新的次数

    // 或者这样
    var myHtml = '';
    $.each(myArray, function(i, item) {
    html += '
  • ' + item + '
  • ';
    });
    $('#ballers').html(myHtml);

    保持简洁风格
    复制代码 代码如下:

    // 不理想
    if ($ventfade.data('currently') != 'showing') {
    $ventfade.stop();
    }
    if ($venthover.data('currently') != 'showing') {
    $venthover.stop();
    }
    if ($spans.data('currently') != 'showing') {
    $spans.stop();
    }
    // 较好的
    var elems = [$ventfade, $venthover, $spans];
    $.each(elems, function(k, v) {
    if (v.data('currently') != 'showing') {
    v.stop();
    }
    })

    慎用匿名函数
    匿名函数的约束到处都是一种痛苦。他们难以调试,维护,测试或重用。相反,我们可以使用对象封装,将那些处理和回调函数组织并通过命名管理起来。
    复制代码 代码如下:

    // 不要这样
    $(document).ready(function() {...
    $('#magic').click(function(e) {
    $('#yayeffects').slideUp(function() {...
    });
    });
    $('#happiness').load(url + ' #unicorns', function() {...
    })
    });

    // 较好的
    var PI = {
    onReady: function() {...
    $('#magic').click(PI.candyMtn);
    $('#happiness').load(url + ' #unicorns', PI.unicornCb);
    },
    candyMtn: function(e) {
    $('#yayeffects').slideUp(PI.slideCb);
    },
    slideCb: function() {...
    },
    unicornCb: function() {...
    }
    }
    $(document).ready(PI.onReady);

    优化选择器
    节点选择和DOM操作, 根据给定的ID匹配一个元素总是使用#id去寻找element
    复制代码 代码如下:

    // 非常快
    $('#container div.robotarm');
    // 超级快
    $('#container').find('div.robotarm');使用$.fn.find方法更快一些,因为第一个选择器是无须经过选择器引擎处理,在jquery中最快的选择器是ID选择器.因为它直接来自于Javascript的getElementById()方法,这是非常快,因为它是原产于浏览器。如果你需要选择多个元素,这必然会涉及到DOM遍历和循环,为了提高性能,建议从最近的ID开始继承。

    具体指定选择器的右侧部分应该尽可能具体,左侧则不需要那么具体。
    复制代码 代码如下:

    // 未优化
    $('div.data .gonzalez');
    // 优化后
    $('.data td.gonzalez');如果可以,尽量在选择器靠右侧的部分使用tag.class,而左侧只有tag或者只有.class。

    避免过度的具体
    复制代码 代码如下:

    $('.data table.attendees td.gonzalez');
    // 不写中间的会更好
    $('.data td.gonzalez');清爽的DOM结构也有助于改善选择器的性能,选择器引擎可以少跑几层去寻觅那个元素了。


    避免使用无定向通配符选择器
    复制代码 代码如下:

    $('.buttons > *'); // 极慢
    $('.buttons').children(); // 快很多
    $('.gender :radio'); // 无定向搜索
    $('.gender *:radio'); // 同上
    $('.gender input:radio'); // 这样 好很多

    使用事件委派

    事件委派允许你为一个容器元素(例如,一个无序列表)绑定一个事件处理程序,而不需给容器内每个元素(例如,列表项)都去绑定。jQuery提供$.fn.live和$.fn.delegate。如果可能的话,你应该使用$.fn.delegate而不是$.fn.live,因为它省去了不必要的选择需要,其明确的情况下(对$.fn.live的文档的上下文),减少了大约80 % 的开销。除了有性能提升的好处,事件委派也使你在往容器里添加新元素时无需重新绑定事件,因为已经有了。

    通过事件委派一次绑定多种事件,以减少事件冗余
    复制代码 代码如下:

    // 不好的 (如果列表里面元素很多)
    $('li.trigger').click(handlerFn);

    // 较好的: event delegation with $.fn.live
    $('li.trigger').live('click', handlerFn);

    // 最优的: $.fn.delegate
    $('#myList').delegate('li.trigger', 'click', handlerFn);

    移除元素
    DOM操作是慢的,你应该尽量避免去操作它。jQuery在1.4版引入了
    $.fn.detach从DOM中去掉所有匹配的元素。
    复制代码 代码如下:

    var $table = $('#myTable');
    var $parent = table.parent();
    $table.detach();
    // ... 添加大量的行到表格中
    $parent.append(table);

    .detach()和.remove()一样, 除了.detach()保存所有jQuery数据和被移走的元素相关联。当需要移走一个元素,不久又将该元素插入DOM时,这种方法很有用。


    当大量元素修改CSS,应该使用样式表

    如果你在用$.fn.css给多于20个元素修改CSS,考虑一下添加一个style标签,这样可以速度可以提升60 % 。
    复制代码 代码如下:

    // 多于20个 明显慢
    $('a.swedberg').css('color', '#asd123');
    $('').appendTo('head');

    使用$.data而不是$.fn.data将$.data应用于DOM元素比直接调用jQuery选择结果的$.fn.data要快上10倍.虽然,这要先确定你是理解DOM元素与jQuery选择结果之间的区别的。
    复制代码 代码如下:

    // 常用
    $(elem).data(key, value);
    // 快十倍
    $.data(elem, key, value);


    别费时间在空白的选择结果上了

    jQuery将不会告诉你,如果你想运行的代码在一个空选择上,它会继续运行,好像没有什么错。影响性能。
    复制代码 代码如下:

    //太遭了,执行了三个方法后才意识到里面是空的
    $('#nosuchthing').slideUp();

    // 较好
    var $mySelection = $('#nosuchthing');
    if ($mySelection.length) {
    mySelection.slideUp();
    }

    // 最佳: 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 widget,因为即使操作的元素为空其开销也不少。



    定义变量
    变量可以定义一个声明而不是几个
    复制代码 代码如下:

    // 老套写法
    var test = 1;
    var test2 = function() {...
    };
    var test3 = test2(test);

    // 新
    var test = 1,
    test2 = function() {...
    },
    test3 = test2(test);在自动执行的函数,变量的定义可以完全省掉。 (function(foo, bar) {...
    })(1, 2);


    条件判断
    复制代码 代码如下:

    // 旧方法
    if (type == 'foo' || type == 'bar') {...
    }

    // 好方法
    if (/^(foo|bar)$/.test(type)) {...
    }

    // 查找对象
    if (({
    foo: 1,
    bar: 1
    })[type]) {...
    }

    作者:曾祥展
    出处:学无止境 (http://www.cnblogs.com/zengxiangzhan/)
    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heißer Artikel

    R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Beste grafische Einstellungen
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    Der Unterschied zwischen vivox100s und x100: Leistungsvergleich und Funktionsanalyse Der Unterschied zwischen vivox100s und x100: Leistungsvergleich und Funktionsanalyse Mar 23, 2024 pm 10:27 PM

    Sowohl die Mobiltelefone vivox100s als auch x100 sind repräsentative Modelle der Mobiltelefonproduktlinie von vivo. Sie repräsentieren jeweils das High-End-Technologieniveau von vivo in unterschiedlichen Zeiträumen. Daher weisen diese beiden Mobiltelefone gewisse Unterschiede in Design, Leistung und Funktionen auf. In diesem Artikel wird ein detaillierter Vergleich dieser beiden Mobiltelefone im Hinblick auf Leistungsvergleich und Funktionsanalyse durchgeführt, um Verbrauchern dabei zu helfen, das für sie geeignete Mobiltelefon besser auszuwählen. Schauen wir uns zunächst den Leistungsvergleich zwischen vivox100s und x100 an. vivox100s ist mit dem Neusten ausgestattet

    So zeigen Sie versteckte Leistungsüberlagerungen in Windows 11 an So zeigen Sie versteckte Leistungsüberlagerungen in Windows 11 an Mar 24, 2024 am 09:40 AM

    In diesem Tutorial helfen wir Ihnen, versteckte Leistungsüberlagerungen in Windows 11 aufzudecken. Mit der Performance-Overlay-Funktion von Windows 11 können Sie Ihre Systemressourcen in Echtzeit überwachen. Sie können die CPU-Auslastung, Festplattenauslastung, GPU-Auslastung, RAM-Auslastung usw. in Echtzeit auf Ihrem Computerbildschirm anzeigen. Dies ist praktisch, wenn Sie Spiele spielen oder große Grafikprogramme (z. B. Videoeditoren) verwenden und überprüfen müssen, wie stark die Systemleistung durch die Verwendung eines bestimmten Programms beeinträchtigt wird. Zwar gibt es hervorragende kostenlose Software zur Überwachung der Systemleistung und einige integrierte Tools wie Resource Monitor können zur Überprüfung der Systemleistung verwendet werden, doch die Leistungsüberlagerungsfunktion hat auch ihre Vorteile. Sie müssen beispielsweise das Programm oder die App, die Sie gerade verwenden, nicht verlassen

    Leistungsvergleich Windows 10 vs. Windows 11: Welches ist besser? Leistungsvergleich Windows 10 vs. Windows 11: Welches ist besser? Mar 28, 2024 am 09:00 AM

    Leistungsvergleich Windows 10 vs. Windows 11: Welches ist besser? Aufgrund der kontinuierlichen Weiterentwicklung und Weiterentwicklung der Technologie werden Betriebssysteme ständig aktualisiert und aktualisiert. Als einer der weltweit größten Betriebssystementwickler hat Microsoft mit seinen Windows-Betriebssystemen schon immer große Aufmerksamkeit bei den Benutzern auf sich gezogen. Im Jahr 2021 veröffentlichte Microsoft das Betriebssystem Windows 11, was breite Diskussionen und Aufmerksamkeit auslöste. Was ist also der Leistungsunterschied zwischen Windows 10 und Windows 11?

    Vergleicht man die Leistung von Win11- und Win10-Systemen: Welches ist besser? Vergleicht man die Leistung von Win11- und Win10-Systemen: Welches ist besser? Mar 27, 2024 pm 05:09 PM

    Das Windows-Betriebssystem war schon immer eines der am weitesten verbreiteten Betriebssysteme auf PCs, und Windows 10 war lange Zeit das Flaggschiff-Betriebssystem von Microsoft, bis Microsoft vor kurzem das neue Windows 11-System auf den Markt brachte. Mit der Einführung des Windows 11-Systems haben sich die Menschen für die Leistungsunterschiede zwischen Windows 10 und Windows 11-Systemen interessiert. Welches ist besser? Werfen wir zunächst einen Blick auf W

    Kirin 8000-Prozessor konkurriert mit Snapdragon-Serie: Wer kann König sein? Kirin 8000-Prozessor konkurriert mit Snapdragon-Serie: Wer kann König sein? Mar 25, 2024 am 09:03 AM

    Im Zeitalter des mobilen Internets sind Smartphones aus dem Alltag der Menschen nicht mehr wegzudenken. Die Leistung von Smartphones bestimmt oft direkt die Qualität des Benutzererlebnisses. Als „Gehirn“ eines Smartphones ist die Leistung des Prozessors besonders wichtig. Auf dem Markt steht die Qualcomm Snapdragon-Serie seit jeher für starke Leistung, Stabilität und Zuverlässigkeit, und kürzlich hat Huawei auch seinen eigenen Kirin 8000-Prozessor auf den Markt gebracht, dem eine hervorragende Leistung nachgesagt wird. Für normale Benutzer ist die Auswahl eines Mobiltelefons mit starker Leistung zu einer zentralen Frage geworden. Heute werden wir es tun

    Vergleich der PHP- und Go-Sprachen: großer Leistungsunterschied Vergleich der PHP- und Go-Sprachen: großer Leistungsunterschied Mar 26, 2024 am 10:48 AM

    PHP und Go sind zwei häufig verwendete Programmiersprachen und weisen unterschiedliche Eigenschaften und Vorteile auf. Unter ihnen sind Leistungsunterschiede ein Problem, das im Allgemeinen allen Sorgen bereitet. In diesem Artikel werden PHP- und Go-Sprachen aus Leistungssicht verglichen und ihre Leistungsunterschiede anhand spezifischer Codebeispiele demonstriert. Lassen Sie uns zunächst kurz die Grundfunktionen von PHP und der Go-Sprache vorstellen. PHP ist eine Skriptsprache, die ursprünglich für die Webentwicklung entwickelt wurde. Sie ist einfach zu erlernen und zu verwenden und wird im Bereich der Webentwicklung häufig verwendet. Die Go-Sprache ist eine von Google entwickelte kompilierte Sprache.

    Die lokale Ausführungsleistung des Embedding-Dienstes übertrifft die von OpenAI Text-Embedding-Ada-002, was sehr praktisch ist! Die lokale Ausführungsleistung des Embedding-Dienstes übertrifft die von OpenAI Text-Embedding-Ada-002, was sehr praktisch ist! Apr 15, 2024 am 09:01 AM

    Ollama ist ein superpraktisches Tool, mit dem Sie Open-Source-Modelle wie Llama2, Mistral und Gemma problemlos lokal ausführen können. In diesem Artikel werde ich vorstellen, wie man Ollama zum Vektorisieren von Text verwendet. Wenn Sie Ollama nicht lokal installiert haben, können Sie diesen Artikel lesen. In diesem Artikel verwenden wir das Modell nomic-embed-text[2]. Es handelt sich um einen Text-Encoder, der OpenAI text-embedding-ada-002 und text-embedding-3-small bei kurzen und langen Kontextaufgaben übertrifft. Starten Sie den nomic-embed-text-Dienst, wenn Sie o erfolgreich installiert haben

    Leistungsvergleich verschiedener Java-Frameworks Leistungsvergleich verschiedener Java-Frameworks Jun 05, 2024 pm 07:14 PM

    Leistungsvergleich verschiedener Java-Frameworks: REST-API-Anforderungsverarbeitung: Vert.x ist am besten, mit einer Anforderungsrate von 2-mal SpringBoot und 3-mal Dropwizard. Datenbankabfrage: HibernateORM von SpringBoot ist besser als ORM von Vert.x und Dropwizard. Caching-Vorgänge: Der Hazelcast-Client von Vert.x ist den Caching-Mechanismen von SpringBoot und Dropwizard überlegen. Geeignetes Framework: Wählen Sie entsprechend den Anwendungsanforderungen. Vert.x eignet sich für leistungsstarke Webdienste, SpringBoot eignet sich für datenintensive Anwendungen und Dropwizard eignet sich für Microservice-Architekturen.

    See all articles