Ready事件

对DOM操作之前需要监听页面加载进度,应当在页面加载完成之后再执行DOM编辑操作。

    $(document).ready(function(){
...
});

或者

    $(function(){
...
});

选择器

1.优先使用原生方法
var el = document.getElementById("element");
2.优先使用id选择器
性能顺序:ID选择器 > 标签选择器 > 类选择器 > 属性选择器 > 伪类选择器

    //性能从上到下递减
$("#element")
$("input")
$(".element")
$("[type=submit]")
$(":hidden")

3.id选择器(getElementById),标签选择器(getElementsByTagName)都有原生方法因此速度很快,类选择器在除了IE6-8之外的主流浏览器都有原生方法(getElementsByClassName)。

var foo = document.getElementById("foo");
var input = document.getElementsByTagName("input");
//IE6-8不支持类选择器
var bar = document.getElementsByClassName("bar");

4.对没有id的元素检索,尽量采用路径最短的祖先元素id作为默认的搜索范围,并采用纯类选择器或者标签选择器。

样式表操作

对一个对象应用多个样式的时候,应尽量使用addClass/removeClass方法,避免多次操作该对象。

var $element = $("#element");
$element.css("width","200px");
$element.css("height","300px");
$element.css("background","#fff"); /*推荐写成这样:*/
.on{
width:200px;
height:200px;
background:#fff;
}
var $element = $("#element");
$element.addClass("on");

选择器保存

如果对同一个元素进行多次操作,推荐将选择器缓存起来或者采用链式写法。

//性能较差
$("#element").click(function(){ });
$("#element").empty();
$("#element").show();
//推荐写法(缓存)
var $element = $("#element");
$element.click(function(){ });
$element.empty();
$element.show();
//推荐写法(链式)
$("#element").click(function(){
//...
}).empty().show();

事件委托

javascript的事件模型,采用"冒泡"模式,也就是说,子元素的事件会逐级向上"冒泡",成为父元素的事件。
当存在以下两种情况是,推荐使用时间委托的写法
  •为DOM中的很多元素绑定相同事件;
  •为DOM中尚不存在的元素绑定事件;

//比如,如果有100个td元素,那么这样写会绑定100次click事件
//性能较差
$("td").click(function(){
//...
});
//推荐写成这样,只需1次将事件绑定在table上
//推荐写法
$("table").on("click","td",function(){
//...
});

事件命名空间

如果可能尽量在绑定事件处理程序时使用一个命名空间,这样可以方便地取消绑定而不会影响其他绑定。

//事件绑定
$("#myLink").on("click.mySpecialClick", myEventHandler);
// 解除绑定
$("#myLink").off("click.mySpecialClick");

合并DOM操作

尽量减少或者合并对DOM的操作。

//性能较差
var i;
var $wrapper = $("#wrapper");
for(i = 0;i<100;i++){
var html = "<div>"+i+"</div>";
$wrapper.append(html);
}
//推荐写法
var i;
var $wrapper = $("#wrapper");
var html = "";
for(i = 0;i<100;i++){
html += "<div>"+i+"</div>";
}
$wrapper.append(html);

JS原生方法

jQuery速度无法与原生的javascript方法相媲美。所以有原生方法可以使用的场合,尽量避免使用jQuery。

/*选择器*/
//性能较差
var id = $(this).attr("id");
//推荐写法
var id = this.id;
/*循环*/
//性能较差
$.each(arr,function(){
...
});
//推荐写法
for(var i = 0;i<arr.length;i++){
...
}

ajax

以下是标准ajax请求模板,事件处理推荐使用promise的写法。

//ajax模板
var successHandler = function(){
//...
};
var failureHandler = function(){
//...
};
var alwaysFunc = function(){
//...
};
var jqxhr = $.ajax({
url: url,
type: "GET", // 默认为GET,你可以根据需要更改
data: {}, // 将请求参数放这里.
dataType: "json", // 指定想要的数据类型
statusCode: { // 如果你想处理各状态的错误的话
404: handler404,
500: handler500
}
});
jqxhr.done(successHandler);
jqxhr.fail(failureHandler);
jqxhr.always(alwaysFunc);

jquery 实践总结的更多相关文章

  1. jQuery实践树(2)

    上一个实践主要对jquery的ready事件进行.本实践要来使用jQuery改变页面的背景图片.可以先试试效果:http://hovertree.com/texiao/jquerytree/2/ 当你 ...

  2. jQuery实践-别踩白块儿网页版

    ▓▓▓▓▓▓ 大致介绍 终于结束了考试,放假回家了.这次的别踩白块儿网页版要比之前做的 jQuery实践-网页版2048小游戏 要简单一点,基本的思路都差不多. 预览:别踩白块网页版 这篇博客并不是详 ...

  3. Jquery实践--精读开篇

    JQuery实践,我已经看了最少三遍了.这里面的很多方法对我的工作很有帮助.但由于不是真的进行前端开发,所以JQuery中的很多功能也没有用到.所以隔一段时间想起,就会发觉,一些东西又忘记了.所以趁这 ...

  4. jquery实践

    转:http://www.cnblogs.com/Wayou/p/jquery_best_prictise.html jQuery编程的最佳实践   好像是feedly订阅里看到的文章,读完后觉得非常 ...

  5. jQuery实践-网页版2048小游戏

    ▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...

  6. jQuery实践——属性和css篇

    属性: attr html:<div>demo1</div> jQuery:$("div").attr("id","demo1 ...

  7. jQuery实践——选择器篇

      一.基本 #id: html:<div id="demo1">demo1</div> jQuery:$("#demo1").css( ...

  8. jquery实践案例--验证电子邮箱

    <input type="email" name="email" id="email" value="" onpa ...

  9. jquery实践案例--验证手机号码

    如果要做手机号的验证,那么我们需要知道手机号码的号段. 182 183 187 188 155 156 176 186 189 //移动运营商:170 移动: 2G号段(GSM):134-139.15 ...

随机推荐

  1. asp.net跳转页面的三种方法比较(转)

    2006-10-20 14:32 [小 大] 来源: 博客园 评论: 0分享至: 百度权重查询 词库网 网站监控 服务器监控 SEO监控 手机游戏 iPhone游戏 今天老师讲了三种跳转页面的方法,现 ...

  2. Fiddler-006-修改HTTP请求参数

    在进行 App 测试时,经常需要修改请求参数,以获得不同的显示效果,以查看相应的页面显示处理.例如:可以通过修改 HTTP请求 的参数,来获取不同的响应结果. 下面以修改 HTTP请求的商品系统编号为 ...

  3. 我的工具箱之Opera浏览器

    下载地址:http://pan.baidu.com/s/1gdVQA11 刚出来时挺火的,后来有点渐趋式微了.

  4. 【原创】storyboard启动应用程序的大致流程

    storyboard启动应用程序的大致流程 [原创] 转载请注明出处:http://i.cnblogs.com/EditPosts.aspx?postid=5395023 1. 用户点击APP图标—— ...

  5. tengine安装lua

    转子: http://www.cnblogs.com/shengshuai/p/4244851.html 参考: http://www.ttlsa.com/nginx/nginx-lua/ 学习:ht ...

  6. 关于更新Ubuntu14.04内核后,virtualbox无法开机vm的问题

    virtualbox和linux内核结合比较紧密,所以当内核意外改动,可能会引起virtualbox无法启动虚拟机,只要尝试启动虚拟机,就会弹出让你执行/etc/init.d/vboxdrv setu ...

  7. 使用Universal USB Installer安装Ubuntu

    1.下载Universal USB Installer 下载地址: 2.下载ubuntu 14 desktop.iso 运行Universal USB Installer,找到电脑上 ubuntu 1 ...

  8. 试用windows Azure

    试用windows Azure, 需要国外手机注册,信用卡注册. windows操作系统,只有2008R2,2012,2012R2可以选择,我选择XS最低档,然后选2012R2,欧洲数据中心,那个慢啊 ...

  9. IOS推荐学习网站

    1> 个人博客:技术大牛 唐巧:http://blog.devtang.com/blog/archives/ 王巍:http://www.onevcat.com 破船之家:http://beyo ...

  10. 文字排版一律用plist

    NSMutableArray *newhealthArr = [NSMutableArray new]; NSArray *healthTitleArr = [NSArray arrayWithCon ...