[转]整理jquery使用好习惯
1.选择器Selector的使用
1)使用id定位性能最好
1.
$(
"#id"
)
2)使用标签名定位,性能其次
1.
$(
"p"
),$(
"div"
),$(
"input"
)
3)使用.class方法对于IE8或者更早版本来说性能很差
1.
$(
".class"
)
4)属性定位性能极差
1.
$(
"[attribute=value]"
)
2.
$(
":hidden"
)
因此组合使用提高性能,减少对dom遍历
1.
$(
"#gbdiv"
).find(
":hidden"
)
2.链式调用
1)坏习惯
1.
$(
"#gbdiv"
).hide();
2.
$(
"#gbdiv"
).css(
"color"
,
"#202020"
);
3.
$(
"#gbdiv"
).show();
2)好习惯
1.
$(
"#gbdiv"
).hide()
2.
.css(
"color"
,
"#202020"
)
3.
.show()
好处在于你不用多次调用$("#gbdiv"),当然,如果你非要这样写,建议你考虑使用缓存方式
3.缓存
1.
var
gbin1=$(
"#gbdiv"
);
2.
gbin1.hide();
3.
gbin1.css(
"color"
,
"#202020"
);
4.
gbin1.show();
4.循环语句
1)坏习惯
1.
var
data = [
"Saab"
,
"Volvo"
,
"BMW"
];
2.
$.each(data,
function
(i, item){
3.
var
newitem=
'<div>'
+ item +
'</div>'
;
4.
$(
"#gbcontainer"
).append(newitem);
5.
});
以上代码中,我们将每一个新添加的tag都作为一个节点添加到容器ID中,实际上jQuery操作节点的成本也不低,更好的方式是尽可能的减少DOM操作
2)好习惯
1.
var
data = [
"Saab"
,
"Volvo"
,
"BMW"
];
2.
var
tmp =
''
;
3.
$.each(data,
function
(i, item){
4.
tmp +=
'<div>'
+ item +
'</div>'
;
5.
});
6.
$(
"#gbcontainer"
).append(tmp);
3)对于字符串特长的,字符串相加在IE6会有性能问题,那就如下
1.
var
data = [
"Saab"
,
"Volvo"
,
"BMW"
];
2.
var
tmp = [];
3.
$.each(data,
function
(i, item){
4.
tmp.push(
'<div>'
+ item +
'</div>'
)
5.
});
6.
$(
"#gbcontainer"
).append(tmp.join(
'\n'
));
5.事件代理
假如gbin1里有1000个div,添加click事件
1)坏习惯
1.
$(
'#gbin1'
).find(
'div'
).click(
function
() {
2.
......
3.
});
你将绑定1000个事件
2)好习惯
1.
$(
'#gbin1'
).on(
'click'
,
'div'
,
function
() {
2.
......
3.
});
使用.on方法,帮助你有效的优化性能:
[转]整理jquery使用好习惯的更多相关文章
- [转]整理jquery开发技巧
1.创建一个嵌套的过滤器 1.$(jquery).filter(":not(:has(.selected))") //去掉所有不包含class为.selected的元素 2.使 ...
- 前端面试题整理—jQuery篇
1.为什么使用jquery,他有哪些好处? 1)轻量级.代码简洁 2)强大的选择器,出色的DOM操作封装 3)有可靠的事件处理机制 4)浏览器兼容性好 5)支持链式操作 6)支持丰富的插件 2.jqu ...
- [整理] jQuery插件开发
1.类级别的插件开发 类级别的插件开发,可似为给jQuery类添加方法,调用方式:$.你的方法(),如:$.ajax() 函数. 1.1.给jQuery类添加方法 $.alertMsg = funct ...
- jQuery选择器使用习惯
http://www.cnblogs.com/fredlau/archive/2009/03/19/1416327.html
- jQuery整理笔记文件夹
jQuery整理笔记文件夹 jQuery整理笔记一----jQuery開始 jQuery整理笔记二----jQuery选择器整理 jQuery整理笔记三----jQuery过滤函数 jQuery整理笔 ...
- 解析Jquery取得iframe中元素的几种方法
iframe在复合文档中经常用到,利用jquery操作iframe可以大幅提高效率,这里收集一些基本操作,需要的朋友可以参考下 DOM方法:父窗口操作IFRAME:window.frames[&q ...
- jQuery 2.0.3 源码分析Sizzle引擎 - 高效查询
为什么Sizzle很高效? 首先,从处理流程上理解,它总是先使用最高效的原生方法来做处理 HTML文档一共有这么四个API: getElementById 上下文只能是HTML文档 浏览器支持情况:I ...
- jQuery从无知到无所不知
说明: 本文以读书笔记的方式整理jQuery的重要知识点,言简意赅,一语中的,删繁就简,引人入胜. 本文先对jQuery强大的功能作一系统的介绍,再详细整理jQuery的选择器.过滤器.DOM操作.事 ...
- 《锋利的Jquery第二版》读书笔记 第一章
按照书本介绍顺序整理jquery库相关的语法.要点. window.onload与$(document).ready()功能类似,前者需要所有资源加载完毕,且不能同时编写多个:后者加载完DOM结构即执 ...
随机推荐
- TypeScript 学习三 类
1,类: 类是TypeScript的核心,大部分代码都是写在类里面: 声明:class 类名{ 属性: 方法(){}:} 注意:类名首字母同样大写,但是方法不需要表明类型,直接写方法名加()即可:属 ...
- 使用visualvm 远程监控 JVM
1. 测试环境 Ubuntu Server 10.01 2. 在服务器上安装 jstatd 组件 使用apt-get 命令安装 openjdk 即可 : sudo apt-get install o ...
- (转载)js 快捷键大全,并有简单使用说明
摘要: (转载)原文链接: http://www.cnblogs.com/fire-phoenix/archive/2010/09/28/1837295.html Code highlighting ...
- 数据集下载 MNIST
The Street View House Numbers (SVHN) Dataset SVHN is a real-world image dataset for developing machi ...
- 视频编辑SDK---我们只提供API,任你自由设计炫酷的功能
面对相对复杂的视频编辑处理技术,你是否束手无策? 在短视频应用中,有一定技术难度的视频编辑技术中,我们提出了一种全新的解决方法:画板和画笔.短视频处理,用画板和画笔,就够了! 我们设计了极其简单易懂的 ...
- CodeForces 706C Hard problem
简单$dp$. $dp[i][0]$:第$i$个串放置完毕,并且第$i$个串不反转,前$i$个串字典序呈非递减的状态下的最小费用. $dp[i][1]$:第$i$个串放置完毕,并且第$i$个串反转,前 ...
- SpringMVC一路总结(一)(转)
itRed You are never too old to set another goal or to dream a new dream. SpringMVC一路总结(一) SpringMVC听 ...
- IE9 浏览器无法捕获中键事件
在silverlight中由于需要添加中键事件,所以通过hook来捕获,但是在IE9上无法运行,该问题是由于IE9设置问题,如下图修改配置, 取消选择即可:
- qemu毒液漏洞分析(2015.9)
0x00背景 安全娱乐圈媒体Freebuf对该漏洞的有关报道: 提供的POC没有触发崩溃,在MJ0011的博客给出了修改后可以使qemu崩溃的poc.详见: http://blogs.360.cn/b ...
- LWP::UserAgent介绍3 -> cookie设置
use LWP::UserAgent; use HTTP::Cookies; my $ua = LWP::UserAgent->new; $ua->cookie_jar(HTTP::Coo ...