JQuery性能优化的几点建议
针对jquery性能优化这个主题,想必大家都有所了解。下面是我搜集点一点资料关于jquery性能优化,大家可以参考参考。
一、选择器性能优化建议
1. 总是从#id选择器来继承:这是jquery选择器的一条黄金法则。jquery选择一个元素最快的方法就是用id来选择了;
2. 在class前面使用tag:jquery中第二快的选择器就是tag选择器(如$(‘head')),因为它和直接来自于原生的javascript方法getelementbytagname()。所以最好总是用tag来修饰class(并且不要忘了就近的id);
3. 使用子查询:将父对象缓存起来以备将来的使用;
4. 采用find(),而不使用上下文查找;
5. 利用强大的链式操作:采用jquery的链式操作比缓存选择器更有效;
二、优化dom操作建议
1.缓存jquery对象: 将你经常用的元素缓存起来;
2. 当要进行dom插入时,将所有元素封装成一个元素:
这里的基本思想是在内存中建立你确实想要的东西,然后更新dom。这并不是一个jquery最佳实践,但必须进行有效的javascript操作 。直接的dom操作速度很慢
直接的dom操作很慢。尽可能少的去更改html结构。
3.使用直接函数,而不要使用与与之等同的函数:为了获得更好的性能,你应该使用直接函数如$.ajax(),而不要使用$.get(),$.getjson(),$.post(),因为后面的几个将会调用$.ajax()。
4. 缓存jquery结果,以备后来使用:
你经常会获得一个javasript应用对象——你可以用app.来保存你经常选择的对象,以备将来使用;
三、关于优化事件性能的建议
1.推迟到$(window).load:
有时候采用$(window).load()比$(document).ready()更快,因为后者不等所有的dom元素都下载完之前执行。你应该在使用它之前测试它。
2.使用event delegation:
当你在一个容器中有许多节点,你想对所有的节点都绑定一个事件,delegation很适合这样的应用场景。使用delegation,我们仅需要在父级绑定事件,然后查看哪个子节点(目标节点)触发了事件。当你有一个很多数据的table的时候,你想对td节点设置事件,这就变得很方便。先获得 table,然后为所有的td节点设置delegation事件
四、其他常用jquery性能优化建议
1. 使用最新版本的jquery
最新的版本往往是最好的。更换了版本后,不要忘记测试你的代码。有时候也不是完全向后兼容的。
2. 使用hmtl5
新的html5标准带来的是更轻巧的dom结构。更轻巧的结构意味着使用jquery需要更少的遍历,以及更优良的载入性能。所以如果可能的话请使用html5。
3. 如果给15个以上的元素加样式时,直接给dom元素添加style标签
要给少数的元素加样式,最好的方法就是使用jquey的css()函数。然而更15个以上的较多的元素添加样式时,直接给dom添加style 标签更有效些。这个方法可以避免在代码中使用硬编码(hard code)。
4. 避免载入多余的代码
将javascript代码放在不同的文件中是个好的方法,仅在需要的时候载入它们。这样你不会载入不必要的代码和选择器。也便于管理代码。
5. 压缩成一个主js文件,将下载次数保持到最少
当你已经确定了哪些文件是应该被载入的,那么将它们打包成一个文件。用一些开源的工具可以自动帮你完成,如使用minify(和你的后端代码集成)或者使用jscompressor,yui compressor 或 dean edwards js packer等在线工具可以为你压缩文件。我最喜欢的是jscompressor。
6. 需要的时候使用原生的javasript
使用jquery是个很棒的事情,但是不要忘了它也是javascript的一个框架。所以你可以在jquery代码有必要的时候也使用原生的javascript函数,这样能获得更好的性能。
7. 从google载入jquery框架
当你的应用正式上线的时候,请从google cdn载入jquery,因为用户可以从最近的地方获取代码。这样你可以减少服务器请求,而用户如果浏览其他网站,而它也使用google cdn的jquery时,就会立即从缓存中调出jquery代码。