热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

编写更好的jQuery代码的建议及优化方法

2019独角兽企业重金招聘Python工程师标准讨论jQuery和javascript性能的文章并不罕见。然而,本文我计划总结一些速度方面的技巧和我本人的一些建

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

讨论jQuery和Javascript性能的文章并不罕见。然而,本文我计划总结一些速度方面的技巧和我本人的一些建议,来提升你的jQuery和Javascript代码。好的代码会带来速度的提升。快速渲染和响应意味着更好的用户体验。

首先,在脑子里牢牢记住jQuery就是Javascript。这意味着我们应该采取相同的编码惯例,风格指南和最佳实践。

首先,如果你是一个Javascript新手,我建议您阅读 《Javascript初学者的最佳实践》 ,这是一篇高质量的Javascript教程,接触jQuery之前最好先阅读。

当你准备使用jQuery,我强烈建议你遵循下面这些指南:

 

缓存变量

DOM遍历是昂贵的,所以尽量将会重用的元素缓存。

01// 糟糕
02
03h = $('#element').height();
04$('#element').css('height',h-20);
05
06// 建议
07
08$element = $('#element');
09h = $element.height();
10$element.css('height',h-20);

 

避免全局变量

jQuery与Javascript一样,一般来说,最好确保你的变量在函数作用域内。

01// 糟糕
02
03$element = $('#element');
04h = $element.height();
05$element.css('height',h-20);
06
07// 建议
08
09var $element = $('#element');
10var h = $element.height();
11$element.css('height',h-20);

 

使用匈牙利命名法

在变量前加$前缀,便于识别出jQuery对象。

01// 糟糕
02
03var first = $('#first');
04var second = $('#second');
05var value = $first.val();
06
07// 建议 - 在jQuery对象前加$前缀
08
09var $first = $('#first');
10var $second = $('#second'),
11var value = $first.val();

 

使用 Var 链(单 Var 模式)

将多条var语句合并为一条语句,我建议将未赋值的变量放到后面。

1var
2  $first = $('#first'),
3  $second = $('#second'),
4  value = $first.val(),
5  k = 3,
6  COOKIEstring = 'SOMECOOKIESPLEASE',
7  i,
8  j,
9  myArray = {};

 

请使用’On’

在新版jQuery中,更短的 on(“click”) 用来取代类似 click() 这样的函数。在之前的版本中 on() 就是 bind()。自从jQuery 1.7版本后,on()?附加事件处理程序的首选方法。然而,出于一致性考虑,你可以简单的全部使用 on()方法。

01// 糟糕
02
03$first.click(function(){
04    $first.css('border','1px solid red');
05    $first.css('color','blue');
06});
07
08$first.hover(function(){
09    $first.css('border','1px solid red');
10})
11
12// 建议
13$first.on('click',function(){
14    $first.css('border','1px solid red');
15    $first.css('color','blue');
16})
17
18$first.on('hover',function(){
19    $first.css('border','1px solid red');
20})

 

精简Javascript

一般来说,最好尽可能合并函数。

01// 糟糕
02
03$first.click(function(){
04    $first.css('border','1px solid red');
05    $first.css('color','blue');
06});
07
08// 建议
09
10$first.on('click',function(){
11    $first.css({
12        'border':'1px solid red',
13        'color':'blue'
14    });
15});

 

链式操作

jQuery实现方法的链式操作是非常容易的。下面利用这一点。

01// 糟糕
02
03$second.html(value);
04$second.on('click',function(){
05    alert('hello everybody');
06});
07$second.fadeIn('slow');
08$second.animate({height:'120px'},500);
09
10// 建议
11
12$second.html(value);
13$second.on('click',function(){
14    alert('hello everybody');
15}).fadeIn('slow').animate({height:'120px'},500);

 

维持代码的可读性

伴随着精简代码和使用链式的同时,可能带来代码的难以阅读。添加缩紧和换行能起到很好的效果。

01// 糟糕
02
03$second.html(value);
04$second.on('click',function(){
05    alert('hello everybody');
06}).fadeIn('slow').animate({height:'120px'},500);
07
08// 建议
09
10$second.html(value);
11$second
12    .on('click',function(){ alert('hello everybody');})
13    .fadeIn('slow')
14    .animate({height:'120px'},500);

 

选择短路求值

短路求值是一个从左到右求值的表达式,用 &&(逻辑与)或 || (逻辑或)操作符。

01// 糟糕
02
03function initVar($myVar) {
04    if(!$myVar) {
05        $myVar = $('#selector');
06    }
07}
08
09// 建议
10
11function initVar($myVar) {
12    $myVar = $myVar || $('#selector');
13}

 

选择捷径

精简代码的其中一种方式是利用编码捷径。

1// 糟糕
2
3if(collection.length > 0){..}
4
5// 建议
6
7if(collection.length){..}

 

繁重的操作中分离元素

如果你打算对DOM元素做大量操作(连续设置多个属性或css样式),建议首先分离元素然后在添加。

01// 糟糕
02
03var
04    $container = $("#container"),
05    $containerLi = $("#container li"),
06    $element = null;
07
08$element = $containerLi.first();
09//... 许多复杂的操作
10
11// better
12
13var
14    $container = $("#container"),
15    $containerLi = $container.find("li"),
16    $element = null;
17
18$element = $containerLi.first().detach();
19//... 许多复杂的操作
20
21$container.append($element);

 

熟记技巧

你可能对使用jQuery中的方法缺少经验,一定要查看的文档,可能会有一个更好或更快的方法来使用它。

1// 糟糕
2
3$('#id').data(key,value);
4
5// 建议 (高效)
6
7$.data('#id',key,value);

 

使用子查询缓存的父元素

正如前面所提到的,DOM遍历是一项昂贵的操作。典型做法是缓存父元素并在选择子元素时重用这些缓存元素。

01// 糟糕
02
03var
04    $container = $('#container'),
05    $containerLi = $('#container li'),
06    $containerLiSpan = $('#container li span');
07
08// 建议 (高效)
09
10var
11    $container = $('#container '),
12    $containerLi = $container.find('li'),
13    $containerLiSpan= $containerLi.find('span');

 

避免通用选择符

将通用选择符放到后代选择符中,性能非常糟糕。

1// 糟糕
2
3$('.container > *');
4
5// 建议
6
7$('.container').children();

避免隐式通用选择符

通用选择符有时是隐式的,不容易发现。

1// 糟糕
2
3$('.someclass :radio');
4
5// 建议
6
7$('.someclass input:radio');

 

优化选择符

例如,Id选择符应该是唯一的,所以没有必要添加额外的选择符。

1// 糟糕
2
3$('div#myid');
4$('div#footer a.myLink');
5
6// 建议
7$('#myid');
8$('#footer .myLink');

 

避免多个ID选择符

在此强调,ID 选择符应该是唯一的,不需要添加额外的选择符,更不需要多个后代ID选择符。

1// 糟糕
2
3$('#outer #inner');
4
5// 建议
6
7$('#inner');

 

坚持最新版本

新版本通常更好:更轻量级,更高效。显然,你需要考虑你要支持的代码的兼容性。例如,2.0版本不支持ie 6/7/8。

 

摒弃弃用方法

关注每个新版本的废弃方法是非常重要的并尽量避免使用这些方法。

01// 糟糕 - live 已经废弃
02
03$('#stuff').live('click'function() {
04  console.log('hooray');
05});
06
07// 建议
08$('#stuff').on('click'function() {
09  console.log('hooray');
10});
11// 注:此处可能不当,应为live能实现实时绑定,delegate或许更合适

 

利用CDN

谷歌的CND能保证选择离用户最近的缓存并迅速响应。(使用谷歌CND请自行搜索地址,此处地址以不能使用,推荐jquery官网提供的CDN)。

必要时组合jQuery和Javascript原生代码

如上所述,jQuery就是Javascript,这意味着用jQuery能做的事情,同样可以用原生代码来做。原生代码(或?vanilla)的可读性和可维护性可能不如jQuery,而且代码更长。但也意味着更高效(通常更接近底层代码可读性越差,性能越高,例如:汇编,当然需要更强大的人才可以)。牢记没有任何框架能比原生代码更小,更轻,更高效(注:测试链接已失效,可上网搜索测试代码)。

鉴于vanilla 和 jQuery之间的性能差异,我强烈建议吸收两人的精华,使用(可能的话)和jQuery等价的原生代码。

 

最后忠告

最后,我记录这篇文章的目的是提高jQuery的性能和其他一些好的建议。如果你想深入的研究对这个话题你会发现很多乐趣。记住,jQuery并非不可或缺,仅是一种选择。思考为什么要使用它。DOM操作?ajax?模版?css动画?还是选择符引擎?或许Javascript微型框架或jQuery的定制版是更好的选择。



转:https://my.oschina.net/leipeng/blog/221386



推荐阅读
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • 本文介绍了如何在Jquery中通过元素的样式值获取元素,并将其赋值给一个变量。提供了5种解决方案供参考。 ... [详细]
  • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
  • 获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法
    本文介绍了获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法,包括使用jQuery的选择器和遍历方法。通过这些方法,可以方便地获取到所需的元素,并进行相应的操作。 ... [详细]
  • 如何压缩网站页面以减少页面加载时间
    本文介绍了影响网站打开时间的两个因素,即网页加载速度和网站页面大小。重点讲解了如何通过压缩网站页面来减少页面加载时间。具体包括图片压缩、Javascript压缩、CSS压缩和HTML压缩等方法,并推荐了相应的压缩工具。此外,还提到了一款Google Chrome插件——网页加载速度分析工具Speed Tracer。 ... [详细]
  • angular.element使用方法及总结
    2019独角兽企业重金招聘Python工程师标准在线查询:http:each.sinaapp.comangularapielement.html使用方法 ... [详细]
  • {moduleinfo:{card_count:[{count_phone:1,count:1}],search_count:[{count_phone:4 ... [详细]
author-avatar
9158Zsc
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有