JS代码优化

加载(js/jq)

1.尽量将JavaScript和jQuery代码放到页面底部。

2.兼容IE6 7 8 不要用2.x的版本

3.不要重复加载和多次加载

4、如果同时还使用了其他JS框架如wap端的Zepto,js框架中,有的也用了$符号,所以你就不要再用$来进行jQuery 编码了,而请用'jQuery'代替。并且调用$.noConflict()保证不会有冲突出现。

变量

1、jQuery类型的变量最好加个$前缀。

2、将常用的jQuery选择器返回的内容存进变量以便重用。

var $myDiv=$("#myDiv");     //多次使用的选择器,存成变量

$myDiv.click(function(){

...

});

3、使用驼峰命名。

选择器

1.尽量ID选择器。实际运用的是js的document.getElementById(),速度最快。

2.使用类选择器时不要指定元素的类型。

var $products=$("div.products");// 慢

var $products=$(".products");// 快

3.ID父亲容器下面查找子元素请用.find()方法,这样快。

$productIds=$("#products div.id");  //差

$productIds=$("#products").find("div.id"); //好

4.多级查找中,右边尽量指定得详细点而左边则尽量简单点。

 $("div.data .gonzalez");  // 不好

 $(".data td.gonzalez");   // 好

5.避免冗余。

$(".data table.attendees td.gonzalez");  //差

$(".data td.gonzalez");    // 去掉了中间的冗余

6.指定选择的上下文。

$('.class');

// 不好:遍历整个DOM查找.class

 $(' .class ' , ' #class-container ' );

//好:在指定容器范围查找

7.避免使用万能选择器。

$( ' div.container > *  ' );   //不好

$('.container').children();  //好

8.警惕隐式的万能选择器。省略的情况下其实使用的就是*号通配符。

$('div.someclass :radio');        //不好

$('div.someclass input:radio');  //好

9.ID已经表示唯一了

$('#outer #inner');        // 差

$('div#inner');              // 差

$('.outer-container #inner');         // 差

$('#inner');      // 好


DOM操作


1.操作元素前先将其拆分,然后贴回去。

var $myList = $("#list-container > ul").detach();

$myList.appendTo("#list-container");

2、使用连接字符串或数组join(),然后再append()。

// 不好

var $myList=$("#list");

for(var i=0;i<10000;i++){

$myList.append("<li>"+ i +"</li>");

}

// 好

var $myList=$("#list");

var list="";

for(var i=0;i<10000;i++){

list += "<li>"+i+"</li>";

}

$myList.html(list);

//更好

var $myList=$("#list");

var array=[ ];

for(var i=0;i<10000;i++){

array[i] = "<li>"+ i +"</li>";

}

$myList.html(array.join(''));

3、不要用缺失的元素

$("#nosuchthing").slideUp();  //差

var $mySelection = $("#nosuchthing");

if ( $mySelection.length ) {

    $mySelection.slideUp();

} // 好

事件

1.一个页面只写一个文档ready事件的处理程序。这样代码既清晰好调试,又容易跟踪代码的进程。

2.不要用匿名函数来做事件的回调。匿名函数不易调试维护测试和复用。或许你想较真,看看这里吧

$("#myLink").on("click",function(){

...

});// 不要这样

function myLinkClickHandler(){

...

}

$("#myLink").on("click",myLinkClickHandler);// 这样

3.处理文档ready事件的回调也表用匿名函数,匿名函数不易调试维护测试和复用

$(function(){

...

});// 不好的做法:无法利用此函数也无法为其写测试用例

$(initPage);// 抑或 $(document).ready(initPage);

functioninitPage(){

// 这里你可以进行程序的初始化了

}// 好的做法

4.进一步,最好也将ready事件的处理程序放到外部文件中引入到页面,而页面中内嵌的代码只需调用即可。

<script src="my-document-ready.js">

// 初始化一些必要的全局变量$(document).ready(initPage);// 抑或 $(initPage);<script>

// 初始化一些必要的全局变量

$(document).ready(initPage); // 或  $(initPage);

</script>

5.千万表写内联到HTML的JS代码,这是调试的噩梦!应该总是用jQuery来绑定事件自带程序,这样也方便随时动态地取消绑定。

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

$("#myLink").on("click.mySpecialClick",myEventHandler);// 不错

// 之后,解除绑定

$("#myLink").unbind("click.mySpecialClick");

7.当选择某个元素的子元素的时候,尽量在后面选择,不要在前面选择其中选择。如下:

$("#list a").on("click",myClickHandler); //不好

$("#list").on("click","a",myClickHandler); //好

Ajax异步操作

1.不要用.getJson() 或 .get(),应直接用$.ajax() ,因为jQuery内部还是将前者转化为$.ajax()

2.不要对HTTPS站点使用HTTP去发起请求,最好干脆就表指定(将HTTP或者HTTPS从你的URL中移除)

3.表在链接里面嵌参数,请使用专门的参数设置来传递

// 不易阅读的代码...

$.ajax({

   url:"something.php?param1=test1&m2=test2",

  ....

});

// 更易阅读...

$.ajax({

     url:"something.php",

     data:{param1:test1,param2:test2}

});

4.尽量指明数据类型以便你自己清楚要处理什么样的数据(见下方会提到的Ajax模板)

5.对于异步动态加载的内容,最好使用代理来绑定事件处理程序。这样的好处是对于之后动态加载的元素事件同样有效。

$("#parent-container").on("click","a",delegatedClickHandlerForAjax);

6.使用Promise模式。

$.ajax({

...

}).then(successHandler( ){

},failureHandler( ){

});

// 或

var jqxhr = $.ajax({

...

});

jqxhr.done(successHandler(){

});   // 成功后,可以多次操作

jqxhr.fail(failureHandler(){

});   // 报错 处理

7.标准的Ajax模板如下

var jqxhr = $.ajax({

     url:url,

     type:"GET",                  // 默认为GET

     cache:true,                   // 默认为true,但对于script,jsonp类型为false,可以自行设置

     data:{              

              // 将请求参数放这里

     },                          

     dataType:"json",           // 指定想要的数据类型

     jsonp:"callback",           // 指定回调处理JSONP类型的请求

     statusCode:{

           // 如果你想处理各状态的错误的话

           404:handler404,

           500:handler500

      }

});

jqxhr.done(successHandler( ){ } );      //成功

jqxhr.fail(failureHandler( ){ } );             //失败

动画与特效

1.保持一个始终如一风格统一的动画实现

2.紧遵用户体验,不要滥用动画特效

插件相关

1.始终选择有良好技术支持团队,文档完善,经过全面测试,并且社区活跃的插件

2.注意所用插件与当前使用的jQuery版本是否兼容

3.一些常用功能应该写成jQuery插件。(延伸,目前一些思路还没整理出来,还在手写的笔记本上)

链式结构

1.除了用变量将jQuery选择器返回的结果保存,还可以利用好链式调用。

$("#myDiv").addClass("error").show();    // 两次/三次比较方便

2.当链式调用多达3次以上或代码因绑定回调略显复杂时,使用换行和适当的缩进来提高代码的可读性。

var MyDiv = $("#myLink") ;


MyDiv.addClass("bold")

       .on("click",myClickHandler)

       .on("mouseover",myMouseOverHandler)

       .show();

3.对于特别长的调用最好还是用变量保存下中间结果来简化代码。

其他

1.使用对象来传递参数

$myLink.attr("href","#").attr("title","my link").attr("rel","external");   //差

$myLink.attr({                         

      href:"#",

      title:"my link",

      rel:"external"

});            // 好

2.尽量避免CSS与jQuery杂揉

$("#mydiv").css({'color':red,'font-weight':'bold'});

// 不好

.error{

        color:red;

        font-weight:bold;

}

$("#mydiv").addClass("error");

// 较好


目前我看网站JS文件中还经常使用live()方法,有时候在动态调用click的时候管用,但是尽量不要用废弃了的方法!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • //------------------------- 第一章 认识JQuery ----------------...
    米塔塔阅读 699评论 0 9
  • 本文以 JavaScript 开发自定义百度地图类型切换控件为主线,记录了控件从实现到一步步优化过程中的思考与总结...
    knightaoko阅读 986评论 0 0
  • Node.js 程序的运行可能会受 CPU 或输入输出操作的限制而十分缓慢。从 CPU 角度看,程序运行缓慢的典型...
    OneAPM阅读 275评论 0 1
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,321评论 0 2
  • 请参看我github中的wiki,不定期更新。https://github.com/ivonzhang/Front...
    zhangivon阅读 7,097评论 2 19