一、合适的选择器

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 性能优化的更多相关文章

  1. jQuery性能优化指南(转载)

    现在jquery应用的越来越多, 有些同学在享受爽快淋漓coding时就将性能问题忽略了, 比如我. jquery虽在诸多的js类库中性能表现还算优秀, 但毕竟不是在用原生的javascript开发, ...

  2. jQuery性能优化的28个建议

    我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...

  3. jQuery:jQuery性能优化28条建议

    http://www.xue5.com/WebDev/jQuery/671700.html 直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将 ...

  4. jquery性能优化的十种方法

    jquery性能优化的十种方法 有时候我们在书写jquery的时候,为了书写代码方便,往往忽略了程序执行过程中,给客户端带来的压力.随之而来的就是在某些低端浏览器或者低端电脑上运行速度缓慢,甚至无法运 ...

  5. jQuery 性能优化技巧

    原文地址:jQuery 性能优化技巧 博客地址:http://www.extlight.com 一.使用最新版本 jQuery 类库 二.合理使用选择器 # 推荐使用 $("#id" ...

  6. jQuery性能优化和技巧

    jQuery性能优化 ①使用最新版本的jQuery类库 ②使用合适的选择器 ③缓存对象 ④循环时的DOM操作 ⑤数组方式使用jQuery对象 ⑥事件代理 ⑦将你的代码转化成jQuery插件 ⑧使用jo ...

  7. 28个jQuery性能优化的建议

    我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...

  8. jQuery性能优化(转)

    摘要:jQuery是我们经常使用的强大的JS类库,因此它的性能优化十分重要,下面就重几点来说明 原文作者:szyuxueliang    原文地址:http://www.cnblogs.com/yxl ...

  9. jQuery性能优化篇

    jQuery高级技巧——性能优化篇 阅读目录 通过CDN(Content Delivery Network)引入jQuery库 减少DOM操作 适当使用原生JS 选择器优化 缓存jQuery对象 定义 ...

  10. jQuery性能优化38建议---最引人注目的用户体验!

    一.需要注意的是的定义jQuery当变量被添加varkeyword 然而,这并不jQuery.整个javascript开发过程,所有需要注意,一定不要将其定义为下面的示例: $loading = $( ...

随机推荐

  1. matlab 函数说明--fspecial

    好吧,这个函数在图像处理中运用得非常广泛,虽然我还是觉得不知道为啥要取这个名字,fspecial的作用如下:         产生一个预定义的2D 滤波器(create a predefined 2D ...

  2. HDU-4716 A Computer Graphics Problem 水题

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4716 直接搞.. //STATUS:C++_AC_0MS_288KB #include <fun ...

  3. jqgrid 设置单元格编辑/不可编辑

    首先设置不可编辑,如下代码: $(', 'not-editable-cell'); 在单元格上设置一个'not-editable-cell'就可以了,如果需要设置为可编辑,那么可以使用下面的代码: f ...

  4. Kooboo中如何切换数据库(注意:如果切换数据库,需要Kooboo中没有一个website 否则会报错数据库中没有表之类的)

    Setup database provider 来自Kooboo document   Kooboo CMS can almost support all the types of database, ...

  5. kvm guest usb mapping

    http://www.linux-kvm.org/page/USB#Input_devices http://www.linux-kvm.org/page/USB_Host_Device_Assign ...

  6. 【推荐】JavaScript的那些书

    又好久没写东西了,写上一篇的时候还以为接下来的工作会轻松一些,结果未从我所愿呐,又是一阵忙碌.而这段时间穿插着做了很多12年淘宝校园招聘的前端面试,很多同学都有问到,学校里没有前端的课程,那如何学习J ...

  7. URL编码原理解释

    当你在浏览器中输入一个URL时,浏览器会将你输入到地址栏的非数字字母转化为URI编码. 那么,它是按照什么样的规则来转换的呢 是这样的,URI编码就是一个字符的ASCII码,它的ACSII码的十六进制 ...

  8. SpringMVC(三)

    今天是学习Spring的第四天,今天终于又把Spring+SpringMVC+Mybatis(SSM)高了一遍,这次运行的代码和配置和昨天的不一样,今天运行的很成功. 主要学习的一点就是我今天使用的是 ...

  9. C#基础知识回顾-- 反射(1)

    C#基础知识回顾-- 反射(1)   反射(reflection)是一种允许用户获得类型信息的C#特性.术语“反射”源自于它的工作方式: Type对象映射它所代表的底层对象.对Type对象进行查询可以 ...

  10. 前端 - 使用gulp搭建es6运行环境

    1.创建一个项目目录2.全局安装Traceur,在控制台输入 npm install -g traceur3.打开项目目录,安装gulp以及gulp-traceur插件 npm install -g ...