JQuery 性能优化
一、合适的选择器
JQuery 选择器提供丰富的选择器来定位DOM元素,
基本选择器
#id、.class、element、*等;那他们哪个更高效呢?
第一选择:
$("#id")
第二选择:
$("p"),$("div")
第三选择(选择性使用) :
$(".class")
第四选择
$("[attribute =value"])
第五选择(伪选择器,其属于 JQuery 过滤选择器中的可见性过滤选择器)
$(":hidden")
PS:1、尽量选择Id选择器,
2、给选择器指定上下文
其类似于CSS选择器,CSS选择器中三大特性 --特殊性、继承、层叠中的特殊性:
1、对于选择器给定的各个ID属性值(#id):加上 0,1,0,0
2、对于选择器给定的各个类属性值(.class、属性选择、伪类如:visited、:link ) : 加上0,0,1,0
3、对于选择器给定的各个元素(element): 加上0,0,0,1
例子:html >body table tr[td="totals"] td ul > li 则为0,0,0,7+ 0,0,1,0 = 0,0,1,7;
li #answer 则为0,0,0,1 + 0,1,0,0 = 0,1,0,1
根据这种运算可以得出胜出规则:
比如:0,1,0,1 大于 0,0,1,7 ,则其特殊性越高。选择的优先级越高。
* 属于通配选择器,其是 0 特殊性
二、数组方式使用JQuery对象
在性能方面,建议使用for 或者 while 来处理,而不是$.each()
如:
$.each(array ,function (i)) {
array[i] = i ;
}
改为:
var array = new Array ();
for (var i = 0 ;i< array.length ;i++) {
array[i] = i;
}
三、事件代理
例子: 单击单元格,单元格变色
$('#table td").click(function()) {
$(this).css("backgroud","blue") ;
}
如果表格有100个td单元格,那么就绑定了100个事件,性能会很差。
可以使用事件代理:
$('#table").click(function(e)) {
var $clicked = $(e.target); // e.target 得到触发的目标元素
$clicked.css("backgroud","blue") ;
}
其只绑定一个事件,性能提高
四、join 拼接字符串
将数组转换为字符串
一般在长字符串时,这个性能提升才会明显
var array = [] ;
for(var i = 0 ; i< 100; i++){
array[i] = '<li>'+i+'</li>';
}
$("#list").html(array.join(' '));
可以联系Java中StringUtils 的Join(), 以及StringBulider,StringBuffer的用法比较使用。
五、使用原生的JS方法
常用判断一个多选框是否选中:
var $ck = $("#ck");
$ck.click(function()) {
if($ck.is(":checked")) {
alert("checked");
}
})
改为:
var $ck = $("#ck");
var ck = $ck.get(0); // JQuery 对象转化为DOM对象,其有2种方式 JQuert.get(0)或者JQuery[0]
$ck.click(function()) {
if(ck.checked)) {
alert("checked");
}
})
六、尽量使用JQuery优雅的链式操作
其可以减少对象的随意创建,也可以创建一个对象到全局环境,让其他函数function调用。
JQuery 性能优化的更多相关文章
- jQuery性能优化指南(转载)
现在jquery应用的越来越多, 有些同学在享受爽快淋漓coding时就将性能问题忽略了, 比如我. jquery虽在诸多的js类库中性能表现还算优秀, 但毕竟不是在用原生的javascript开发, ...
- jQuery性能优化的28个建议
我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...
- jQuery:jQuery性能优化28条建议
http://www.xue5.com/WebDev/jQuery/671700.html 直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将 ...
- jquery性能优化的十种方法
jquery性能优化的十种方法 有时候我们在书写jquery的时候,为了书写代码方便,往往忽略了程序执行过程中,给客户端带来的压力.随之而来的就是在某些低端浏览器或者低端电脑上运行速度缓慢,甚至无法运 ...
- jQuery 性能优化技巧
原文地址:jQuery 性能优化技巧 博客地址:http://www.extlight.com 一.使用最新版本 jQuery 类库 二.合理使用选择器 # 推荐使用 $("#id" ...
- jQuery性能优化和技巧
jQuery性能优化 ①使用最新版本的jQuery类库 ②使用合适的选择器 ③缓存对象 ④循环时的DOM操作 ⑤数组方式使用jQuery对象 ⑥事件代理 ⑦将你的代码转化成jQuery插件 ⑧使用jo ...
- 28个jQuery性能优化的建议
我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...
- jQuery性能优化(转)
摘要:jQuery是我们经常使用的强大的JS类库,因此它的性能优化十分重要,下面就重几点来说明 原文作者:szyuxueliang 原文地址:http://www.cnblogs.com/yxl ...
- jQuery性能优化篇
jQuery高级技巧——性能优化篇 阅读目录 通过CDN(Content Delivery Network)引入jQuery库 减少DOM操作 适当使用原生JS 选择器优化 缓存jQuery对象 定义 ...
- jQuery性能优化38建议---最引人注目的用户体验!
一.需要注意的是的定义jQuery当变量被添加varkeyword 然而,这并不jQuery.整个javascript开发过程,所有需要注意,一定不要将其定义为下面的示例: $loading = $( ...
随机推荐
- 当很多连接到你的数据库时,报这种错误“已超过了锁请求超时时段” SqlServer数据库正在还原的解决办法
1)管理器不会主动刷新,需要手工刷新一下才能看到最新状态(性能方面的考虑) 2)很少情况下,恢复进程被挂起了.这个时候假设你要恢复并且回到可访问状态,要执行: RESTORE database ...
- PopupWindow 问题集锦
1.响应返回键/响应键盘事件(onKeyListener) 最近在做PopupWindow, 发现使用PopupWindow一出现,不会响应popup外面的事件,经过资料查找,发现有两种方法可以响应外 ...
- class-dump 复制到/usr/bin目录不可写,Operation not permitted 解决办法
许多升级了OSX 10.11的朋友在配置class-dump的时候,会发现书上推荐的class-dump存放目录/usr/bin不再可写,如下所示: Operation not permitted 把 ...
- Asp.Net事务和异常处理:
Asp.Net事务和异常处理: 一.什么是事务处理? 事务处理是一组组和成逻辑工作单元的数据库操作,虽然系统中可能会出错,但事务将控制和维护每个数据库的一致性和完整性. 如果在事务过程中没有遇到错误, ...
- Gitbook 使用入门
GitBook 是一个基于 Node.js 的命令行工具,可使用 Github/Git 和 Markdown 来制作精美的电子书. 本书将简单介绍如何安装.编写.生成.发布一本在线图书. http:/ ...
- 【推荐】对 Linux 用户非常有用的 60 个命令(由浅入深)
对 Linux 新手非常有用的 20 个命令 http://www.oschina.net/translate/useful-linux-commands-for-newbies 对 Linux 中级 ...
- iOS——UIButton响应传参数
- (void)addTarget:(id)target action:(SEL)action forControlEvents:(UIControlEvents)controlEvents; 方法是 ...
- Android手机上判断网络运营商
我们想获取手机的运营商信息.通常都会去调用系统的TelephonyManager类的取数据.但是很多时候可能取不到卡的信息(例如双卡手机和 一些特殊卡),这样就区别不了运营商了.但是有时候我们的需求要 ...
- android学习日记0--开发需要掌握的技能
一.开发android,我们需要哪些技能基础 1.Java基础知识 2.Linux基础知识 3.数据库基础知识 4.网络协议 5.Android基础知识 6.服务器端开发知识 1.Java基础知识 很 ...
- android学习日记06--View视图
一.android 界面开发 1.三个重要的类:View视图.Canvas画布.Paint画笔2.android 界面开发常用三种视图 View --只能在主线程中更新,没有缓存 ...