- 浏览: 27372 次
- 性别:
- 来自: 武汉
文章分类
最新评论
讨论jQuery和javascript性能的文章并不罕见。然而,本文我计划总结一些速度方面的技巧和我本人的一些建议,来提升你的jQuery和javascript代码。好的代码会带来速度的提升。快速渲染和响应意味着更好的用户体验。
首先,在脑子里牢牢记住jQuery就是javascript。这意味着我们应该采取相同的编码惯例,风格指南和最佳实践。
首先,如果你是一个javascript新手,我建议您阅读 《JavaScript初学者的最佳实践》 ,这是一篇高质量的javascript教程,接触jQuery之前最好先阅读。
当你准备使用jQuery,我强烈建议你遵循下面这些指南:
缓存变量
DOM遍历是昂贵的,所以尽量将会重用的元素缓存。
// 糟糕
h = $('#element').height();
$('#element').css('height',h-20);
// 建议
$element = $('#element');
h = $element.height();
$element.css('height',h-20);
避免全局变量
jQuery与javascript一样,一般来说,最好确保你的变量在函数作用域内。
// 糟糕
$element = $('#element');
h = $element.height();
$element.css('height',h-20);
// 建议
var $element = $('#element');
var h = $element.height();
$element.css('height',h-20);
使用匈牙利命名法
在变量前加$前缀,便于识别出jQuery对象。
// 糟糕
var first = $('#first');
var second = $('#second');
var value = $first.val();
// 建议 - 在jQuery对象前加$前缀
var $first = $('#first');
var $second = $('#second'),
var value = $first.val();
使用 Var 链(单 Var 模式)
将多条var语句合并为一条语句,我建议将未赋值的变量放到后面。
var
$first = $('#first'),
$second = $('#second'),
value = $first.val(),
k = 3,
cookiestring = 'SOMECOOKIESPLEASE',
i,
j,
myArray = {};
请使用’On’
在新版jQuery中,更短的 on(“click”) 用来取代类似 click() 这样的函数。在之前的版本中 on() 就是 bind()。自从jQuery 1.7版本后,on()?附加事件处理程序的首选方法。然而,出于一致性考虑,你可以简单的全部使用 on()方法。
// 糟糕
$first.click(function(){
$first.css('border','1px solid red');
$first.css('color','blue');
});
$first.hover(function(){
$first.css('border','1px solid red');
})
// 建议
$first.on('click',function(){
$first.css('border','1px solid red');
$first.css('color','blue');
})
$first.on('hover',function(){
$first.css('border','1px solid red');
})
精简javascript
一般来说,最好尽可能合并函数。
// 糟糕
$first.click(function(){
$first.css('border','1px solid red');
$first.css('color','blue');
});
// 建议
$first.on('click',function(){
$first.css({
'border':'1px solid red',
'color':'blue'
});
});
链式操作
jQuery实现方法的链式操作是非常容易的。下面利用这一点。
// 糟糕
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
});
$second.fadeIn('slow');
$second.animate({height:'120px'},500);
// 建议
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
}).fadeIn('slow').animate({height:'120px'},500);
维持代码的可读性
伴随着精简代码和使用链式的同时,可能带来代码的难以阅读。添加缩紧和换行能起到很好的效果。
// 糟糕
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
}).fadeIn('slow').animate({height:'120px'},500);
// 建议
$second.html(value);
$second
.on('click',function(){ alert('hello everybody');})
.fadeIn('slow')
.animate({height:'120px'},500);
选择短路求值
短路求值是一个从左到右求值的表达式,用 &&(逻辑与)或 || (逻辑或)操作符。
// 糟糕
function initVar($myVar) {
if(!$myVar) {
$myVar = $('#selector');
}
}
// 建议
function initVar($myVar) {
$myVar = $myVar || $('#selector');
}
选择捷径
精简代码的其中一种方式是利用编码捷径。
// 糟糕
if(collection.length > 0){..}
// 建议
if(collection.length){..}
繁重的操作中分离元素
如果你打算对DOM元素做大量操作(连续设置多个属性或css样式),建议首先分离元素然后在添加。
// 糟糕
var
$container = $("#container"),
$containerLi = $("#container li"),
$element = null;
$element = $containerLi.first();
//... 许多复杂的操作
// better
var
$container = $("#container"),
$containerLi = $container.find("li"),
$element = null;
$element = $containerLi.first().detach();
//... 许多复杂的操作
$container.append($element);
熟记技巧
你可能对使用jQuery中的方法缺少经验,一定要查看的文档,可能会有一个更好或更快的方法来使用它。
// 糟糕
$('#id').data(key,value);
// 建议 (高效)
$.data('#id',key,value);
使用子查询缓存的父元素
正如前面所提到的,DOM遍历是一项昂贵的操作。典型做法是缓存父元素并在选择子元素时重用这些缓存元素。
// 糟糕
var
$container = $('#container'),
$containerLi = $('#container li'),
$containerLiSpan = $('#container li span');
// 建议 (高效)
var
$container = $('#container '),
$containerLi = $container.find('li'),
$containerLiSpan= $containerLi.find('span');
避免通用选择符
将通用选择符放到后代选择符中,性能非常糟糕。
// 糟糕
$('.container > *');
// 建议
$('.container').children();
避免隐式通用选择符
通用选择符有时是隐式的,不容易发现。
// 糟糕
$('.someclass :radio');
// 建议
$('.someclass input:radio');
优化选择符
例如,Id选择符应该是唯一的,所以没有必要添加额外的选择符。
// 糟糕
$('div#myid');
$('div#footer a.myLink');
// 建议
$('#myid');
$('#footer .myLink');
避免多个ID选择符
在此强调,ID 选择符应该是唯一的,不需要添加额外的选择符,更不需要多个后代ID选择符。
// 糟糕
$('#outer #inner');
// 建议
$('#inner');
坚持最新版本
新版本通常更好:更轻量级,更高效。显然,你需要考虑你要支持的代码的兼容性。例如,2.0版本不支持ie 6/7/8。
摒弃弃用方法
关注每个新版本的废弃方法是非常重要的并尽量避免使用这些方法。
// 糟糕 - live 已经废弃
$('#stuff').live('click', function() {
console.log('hooray');
});
// 建议
$('#stuff').on('click', function() {
console.log('hooray');
});
// 注:此处可能不当,应为live能实现实时绑定,delegate或许更合适
利用CDN
谷歌的CND能保证选择离用户最近的缓存并迅速响应。(使用谷歌CND请自行搜索地址,此处地址以不能使用,推荐jquery官网提供的CDN)。
必要时组合jQuery和javascript原生代码
如上所述,jQuery就是javascript,这意味着用jQuery能做的事情,同样可以用原生代码来做。原生代码(或?vanilla)的可读性和可维护性可能不如jQuery,而且代码更长。但也意味着更高效(通常更接近底层代码可读性越差,性能越高,例如:汇编,当然需要更强大的人才可以)。牢记没有任何框架能比原生代码更小,更轻,更高效(注:测试链接已失效,可上网搜索测试代码)。
鉴于vanilla 和 jQuery之间的性能差异,我强烈建议吸收两人的精华,使用(可能的话)和jQuery等价的原生代码。
最后忠告
最后,我记录这篇文章的目的是提高jQuery的性能和其他一些好的建议。如果你想深入的研究对这个话题你会发现很多乐趣。记住,jQuery并非不可或缺,仅是一种选择。思考为什么要使用它。DOM操作?ajax?模版?css动画?还是选择符引擎?或许javascript微型框架或 jQuery的定制版是更好的选择。
转自:http://www.linuxeden.com/html/news/20131205/146158.html
附加说明:
$.data 注意:这是一个底层方法。你应当使用.data()来代替。
此方法在jQuery 1.8中删除,但你仍然可以通过$._data(element, "events")调试事件数据。请注意,这是不支持的公共接口;实际的数据结构可能会改变从版本之间不兼容。
首先,在脑子里牢牢记住jQuery就是javascript。这意味着我们应该采取相同的编码惯例,风格指南和最佳实践。
首先,如果你是一个javascript新手,我建议您阅读 《JavaScript初学者的最佳实践》 ,这是一篇高质量的javascript教程,接触jQuery之前最好先阅读。
当你准备使用jQuery,我强烈建议你遵循下面这些指南:
缓存变量
DOM遍历是昂贵的,所以尽量将会重用的元素缓存。
// 糟糕
h = $('#element').height();
$('#element').css('height',h-20);
// 建议
$element = $('#element');
h = $element.height();
$element.css('height',h-20);
避免全局变量
jQuery与javascript一样,一般来说,最好确保你的变量在函数作用域内。
// 糟糕
$element = $('#element');
h = $element.height();
$element.css('height',h-20);
// 建议
var $element = $('#element');
var h = $element.height();
$element.css('height',h-20);
使用匈牙利命名法
在变量前加$前缀,便于识别出jQuery对象。
// 糟糕
var first = $('#first');
var second = $('#second');
var value = $first.val();
// 建议 - 在jQuery对象前加$前缀
var $first = $('#first');
var $second = $('#second'),
var value = $first.val();
使用 Var 链(单 Var 模式)
将多条var语句合并为一条语句,我建议将未赋值的变量放到后面。
var
$first = $('#first'),
$second = $('#second'),
value = $first.val(),
k = 3,
cookiestring = 'SOMECOOKIESPLEASE',
i,
j,
myArray = {};
请使用’On’
在新版jQuery中,更短的 on(“click”) 用来取代类似 click() 这样的函数。在之前的版本中 on() 就是 bind()。自从jQuery 1.7版本后,on()?附加事件处理程序的首选方法。然而,出于一致性考虑,你可以简单的全部使用 on()方法。
// 糟糕
$first.click(function(){
$first.css('border','1px solid red');
$first.css('color','blue');
});
$first.hover(function(){
$first.css('border','1px solid red');
})
// 建议
$first.on('click',function(){
$first.css('border','1px solid red');
$first.css('color','blue');
})
$first.on('hover',function(){
$first.css('border','1px solid red');
})
精简javascript
一般来说,最好尽可能合并函数。
// 糟糕
$first.click(function(){
$first.css('border','1px solid red');
$first.css('color','blue');
});
// 建议
$first.on('click',function(){
$first.css({
'border':'1px solid red',
'color':'blue'
});
});
链式操作
jQuery实现方法的链式操作是非常容易的。下面利用这一点。
// 糟糕
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
});
$second.fadeIn('slow');
$second.animate({height:'120px'},500);
// 建议
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
}).fadeIn('slow').animate({height:'120px'},500);
维持代码的可读性
伴随着精简代码和使用链式的同时,可能带来代码的难以阅读。添加缩紧和换行能起到很好的效果。
// 糟糕
$second.html(value);
$second.on('click',function(){
alert('hello everybody');
}).fadeIn('slow').animate({height:'120px'},500);
// 建议
$second.html(value);
$second
.on('click',function(){ alert('hello everybody');})
.fadeIn('slow')
.animate({height:'120px'},500);
选择短路求值
短路求值是一个从左到右求值的表达式,用 &&(逻辑与)或 || (逻辑或)操作符。
// 糟糕
function initVar($myVar) {
if(!$myVar) {
$myVar = $('#selector');
}
}
// 建议
function initVar($myVar) {
$myVar = $myVar || $('#selector');
}
选择捷径
精简代码的其中一种方式是利用编码捷径。
// 糟糕
if(collection.length > 0){..}
// 建议
if(collection.length){..}
繁重的操作中分离元素
如果你打算对DOM元素做大量操作(连续设置多个属性或css样式),建议首先分离元素然后在添加。
// 糟糕
var
$container = $("#container"),
$containerLi = $("#container li"),
$element = null;
$element = $containerLi.first();
//... 许多复杂的操作
// better
var
$container = $("#container"),
$containerLi = $container.find("li"),
$element = null;
$element = $containerLi.first().detach();
//... 许多复杂的操作
$container.append($element);
熟记技巧
你可能对使用jQuery中的方法缺少经验,一定要查看的文档,可能会有一个更好或更快的方法来使用它。
// 糟糕
$('#id').data(key,value);
// 建议 (高效)
$.data('#id',key,value);
使用子查询缓存的父元素
正如前面所提到的,DOM遍历是一项昂贵的操作。典型做法是缓存父元素并在选择子元素时重用这些缓存元素。
// 糟糕
var
$container = $('#container'),
$containerLi = $('#container li'),
$containerLiSpan = $('#container li span');
// 建议 (高效)
var
$container = $('#container '),
$containerLi = $container.find('li'),
$containerLiSpan= $containerLi.find('span');
避免通用选择符
将通用选择符放到后代选择符中,性能非常糟糕。
// 糟糕
$('.container > *');
// 建议
$('.container').children();
避免隐式通用选择符
通用选择符有时是隐式的,不容易发现。
// 糟糕
$('.someclass :radio');
// 建议
$('.someclass input:radio');
优化选择符
例如,Id选择符应该是唯一的,所以没有必要添加额外的选择符。
// 糟糕
$('div#myid');
$('div#footer a.myLink');
// 建议
$('#myid');
$('#footer .myLink');
避免多个ID选择符
在此强调,ID 选择符应该是唯一的,不需要添加额外的选择符,更不需要多个后代ID选择符。
// 糟糕
$('#outer #inner');
// 建议
$('#inner');
坚持最新版本
新版本通常更好:更轻量级,更高效。显然,你需要考虑你要支持的代码的兼容性。例如,2.0版本不支持ie 6/7/8。
摒弃弃用方法
关注每个新版本的废弃方法是非常重要的并尽量避免使用这些方法。
// 糟糕 - live 已经废弃
$('#stuff').live('click', function() {
console.log('hooray');
});
// 建议
$('#stuff').on('click', function() {
console.log('hooray');
});
// 注:此处可能不当,应为live能实现实时绑定,delegate或许更合适
利用CDN
谷歌的CND能保证选择离用户最近的缓存并迅速响应。(使用谷歌CND请自行搜索地址,此处地址以不能使用,推荐jquery官网提供的CDN)。
必要时组合jQuery和javascript原生代码
如上所述,jQuery就是javascript,这意味着用jQuery能做的事情,同样可以用原生代码来做。原生代码(或?vanilla)的可读性和可维护性可能不如jQuery,而且代码更长。但也意味着更高效(通常更接近底层代码可读性越差,性能越高,例如:汇编,当然需要更强大的人才可以)。牢记没有任何框架能比原生代码更小,更轻,更高效(注:测试链接已失效,可上网搜索测试代码)。
鉴于vanilla 和 jQuery之间的性能差异,我强烈建议吸收两人的精华,使用(可能的话)和jQuery等价的原生代码。
最后忠告
最后,我记录这篇文章的目的是提高jQuery的性能和其他一些好的建议。如果你想深入的研究对这个话题你会发现很多乐趣。记住,jQuery并非不可或缺,仅是一种选择。思考为什么要使用它。DOM操作?ajax?模版?css动画?还是选择符引擎?或许javascript微型框架或 jQuery的定制版是更好的选择。
转自:http://www.linuxeden.com/html/news/20131205/146158.html
附加说明:
$.data 注意:这是一个底层方法。你应当使用.data()来代替。
此方法在jQuery 1.8中删除,但你仍然可以通过$._data(element, "events")调试事件数据。请注意,这是不支持的公共接口;实际的数据结构可能会改变从版本之间不兼容。
发表评论
-
深入理解javascript语言中的this
2014-12-07 11:46 1215说到js中的函数中的this指针,就像是悟空的毫毛一样,可以随 ... -
javascript中函数作用域和全局作用域
2014-12-03 17:41 973在地址:http://www.cnblogs.com/shar ... -
关于编写性能高效的javascript事件的技术
2014-12-03 11:00 517转自:http://www.cnblogs.com/sharp ... -
javascript中如何声明一个全局对象
2014-12-02 21:23 667一般我们都知道直接在任何方法外面使用var关键字声明的变量就是 ... -
阿里淘宝的js命名空间函数namespace
2014-12-02 18:47 1012在使用阿里开源的druid数据库连接池时,发现它的jar包中包 ... -
jQuery1.11.1源代码初步剖析
2014-11-30 18:29 1783jQuery是web程序员的必备js库,估计90%以上的web ... -
JSTL标签遍历map list
2014-11-25 17:47 3234使用jsp的标签库,遍历一个元素为map的List: List ... -
jquery绑定事件失效的情况
2014-11-20 21:15 2357现在的web项目,不使用j ... -
submit表单使用javascript函数控制提交
2013-11-01 13:09 1547为了说明情况,下面的代码是经过简化的演示: <in ... -
javascript的执行并非完全同步
2013-11-01 13:08 0为了说明情况,下面的代码是经过简化的演示: <in ... -
input 为disabled 引起的java.lang.NullPointerException
2013-10-31 10:47 1458最近遇到一个空指针异常: 严重: Servlet.serv ...
相关推荐
这个压缩包包含的代码文件旨在帮助观众更好地理解和实践视频中的讲解内容,提供了丰富的实例和练习,以促进JavaScript库jQuery的深入学习。 jQuery是一个强大的JavaScript库,它简化了HTML文档遍历、事件处理、动画...
3. **执行jQuery代码**:一旦jQuery库加载完毕,我们就可以在控制台中编写和执行jQuery代码了。比如,查找页面上的某个元素并改变它的样式: ```javascript $('body').css('background-color', 'red'); ``` 这将...
3. CSS文件(可选):"Tetris.css",用于分离样式和结构,提供更好的代码组织和页面样式。 4. 图片资源(可选):可能包括方块的不同形状和游戏元素的图片。 在开发过程中,为了优化性能,开发者可能使用了一些...
标题 "dreamware jquery 代码提示" 指的是一个与 Dreamware 开发工具相关的 jQuery 代码提示功能。...通过以上这些知识的学习和实践,你可以更好地利用 Dreamware 的 jQuery 代码提示功能,提升你的前端开发能力。
**jQuery 是一个高效、简洁且功能...通过合理利用这些代码片段,开发者可以在保持代码质量的同时,更好地专注于应用程序的逻辑和创新。要深入了解和熟练使用这些代码片段,可以参考“使用方法.txt”文件中的详细指南。
在编写高效的jQuery代码时,有几个关键点需要注意,以优化性能并提供更好的用户体验。首先,我们需要理解jQuery实际上是在JavaScript的基础上构建的,因此遵循良好的JavaScript编码习惯是至关重要的。 **缓存变量**...
**jQuery代码详解** jQuery是一个广泛使用的JavaScript库,它极大地简化了JavaScript的DOM操作、事件处理、动画设计和Ajax交互。...通过研究和学习这些代码,你将能够更好地掌握jQuery的精髓,提升你的前端开发技能。
为了在DW中更方便地编写jQuery代码,开发者通常会使用特定的代码提示插件,如“dw5对jQuery代码提示插件”。 该插件专为Dreamweaver 5设计,旨在提供对jQuery语法的智能提示功能,帮助开发者在编写过程中快速找到所...
这本书的随书代码包含了所有实例和示例,帮助读者更好地理解和应用jQuery技术。 jQuery是一个轻量级的JavaScript库,它极大地简化了JavaScript的使用,让网页动态化、事件处理、动画制作和Ajax交互变得更加容易。在...
通过学习“精通javascript和jquery代码”,你可以掌握如何利用这两种工具创建动态网页。书中实例将提供实际操作的机会,让你能亲手实践并加深理解。这包括对基本概念的练习,以及如何将这些知识应用于解决实际问题,...
在网页设计中,交互性和用户体验是非常重要的因素,而下拉菜单是实现这一目标的常见工具。...同时,理解并运用这段代码也能帮助开发者更好地理解jQuery库的工作原理,为进一步深入学习前端开发打下坚实的基础。
其次详细讲解了jQuery的各种选择器、jQuery操作DOM的方法、jQuery中的事件与应用、jQuery中的动画和特效、Ajax在jQuery中的应用,以及各种常用的jQuery插件的使用方法和技巧...
在开发Web应用时,将Grails(一个基于Groovy语言的开源全栈式Web应用框架)...不过,要注意保持代码组织的清晰,避免过度依赖JQuery,适时考虑使用现代JavaScript库或框架,如React或Vue.js,以实现更好的组件化开发。
这个名为“Jquery代码示例.rar”的压缩包显然包含了一些使用jQuery编写的代码实例,旨在帮助开发者更好地理解和学习jQuery的核心功能和常见用法。 首先,jQuery的引入通常是通过在HTML文档的`<head>`部分添加一个`...
通过使用jQuery,开发者可以编写更简洁、更高效的代码,使得页面动态效果的实现更加便捷。 在该代码中,关键在于滑块(slider)组件的实现。jQuery UI库提供了滑块插件,允许创建可拖动的滑动条。通过设置滑块的...
《jQuery 1.2与1.3:源代码解析与技术演进》 jQuery,作为JavaScript库的杰出代表,以其简洁的API和强大的功能深受开发者...对于开发者来说,深入理解这些源代码,有助于提升自身技能,更好地运用jQuery进行Web开发。
它的语法简洁、易懂,使得开发者能够更高效地编写跨浏览器的JavaScript代码。对于初学者而言,jQuery是进入Web开发的一个理想起点。 **基本使用** jQuery的核心在于选择器,它允许我们轻松地选取页面中的HTML元素...
`js`目录包含了JavaScript文件,其中最重要的是使用jQuery编写的实现拼图相册功能的脚本。这些脚本可能涉及到以下技术点: 1. 图片加载和预处理:使用jQuery的`$.get()`或`$.ajax()`来异步加载图片,然后进行切割。 ...
在IT行业中,jQuery是一个非常流行的JavaScript库,它简化了HTML文档遍历、事件处理、动画设计和Ajax交互等任务。...通过深入理解并实践此类代码,开发者可以更好地掌握jQuery库及其在实际项目中的应用。