網(wǎng)頁制作JS代碼優(yōu)化經(jīng)驗(yàn)總結(jié)

2022-06-12發(fā)布者:ylm大?。?/span> 下載:0

文件大小:

軟件介紹

  

這些是我寫代碼時的一些經(jīng)驗(yàn),總結(jié)了一下分想給大家,沒啥順序,想到就寫上了

1.使用局部變量避免使用全局變量
比如


function test(){
                var s = document.getElementById(aaa);
                s.innerHTML = document.body.clientHeight;
        }
 改成


function test(){
                var d = document;
                        s = d.getElementById(aaa);
                s.innerHTML = d.body.clientHeight;
        }
局部變量的好處就是減少了作用域鏈的查找
我建議要是有兩次的引用就用局部變量

2.避免使用with(這個估計(jì)地球人都知道)

我理解原因就是with會創(chuàng)建自己的作用域,這樣就加長了原來的作用域鏈,使得在with塊中執(zhí)行的代碼反而變慢了,在書寫上好像省了代碼,其實(shí)在訪問上反而變長變繁瑣了,性能下降了
例子
        使用with


function test(){
                        with(document.body){
                                clientHeight = 200px;
                                clientWidth = 200px
                        }
                }

        其實(shí)都可以寫成


function test(){
                        var ds = document.body;
                        ds.clientHeight = 200px;
                        ds.clientWidth = 200px
                }

3. 遍歷nodelist的方式

 一般的方式都是

var as = document.getElementsByTagName(div);
        for(var i=0,l<as.length;i<l;i++){//只計(jì)算一次長度}
        我的方式一次都不用
        for(var i=0,ci;ci=as[i++];){}當(dāng)nodeList完結(jié)時就為false就結(jié)束了
        好處,沒計(jì)算長度,省了在循環(huán)里賦值,代碼更加少了,i++到了判斷里
(注意:這個方式用在nodelist里可以,如果你用到array里,可會有問題的,數(shù)組里有個0后者null什么的就瞎了)
 

4.別用那么多個var,一個加逗號就搞定了

var a =1;
        var b = 1;
        var c =1;
        代碼長,性能差
        拆成
        var a=1,
                b=1,
                c=1;

 5.innerHTML是最好的選擇

往元素添加元素時,最好用innerHTML

6.ie的removeChild不好用

一般咱們刪除一個元素會用

elm.removeChild(subElm)

這個在ie下不好用,因?yàn)樵趇e下這個只是把這個元素從dom樹中斷開了,但并沒用真正刪除,它現(xiàn)在變成了孤立的節(jié)點(diǎn)了,要想真正刪除,可以這樣


var ryc = document.createElement(div);
        div.appendChild(subElm);
        div.innerHTML = ;
        div = null;

這樣就真的刪除了,除了ie外別的都可以用removeChild達(dá)到效果

7.為多個同級元素綁定事件時,不用為每個都綁定,為他們的父級綁定就行了
比如

<ul id="a">
                <li>sdf</li><li>sdf</li><li>sdf</li><li>sdf</li><li>sdf</li><li>sdf</li>
        </ul>
可能你要為每個li添加click

為每個添加那可繁瑣且容易出現(xiàn)溢出(ie)

其實(shí)只要為 ul一個添加就行了,因?yàn)槭录敲芭菹蛏系?/p>


var ul = document.getElementById(a);
        ul.onclick = function (e){
                !e&&(e=event);
                var target = e.srcElement||e.target;
                if(target.tagName==LI){
                        //your code
                }
        }
 

8.盡量用原生的方法,因?yàn)樵亩际怯胏/c++編譯而成的他們執(zhí)行的要比用js寫的方法快多了
9.appendChild用的多時一定要用docuemntfragment

比如
        for(var i=0;i<1000;i++){
                var o = document.createElement(div);
                document.body.appendChild(o);
        }
用documentFragment


var f = document.createDocumentFragment();
        for(var i=0;i<1000;i++){
                var o = document.createElement(div);
                f.appendChild(o);
        }
        document.body.appendChild(f);
10. if else用的>=3個了,那用switch吧,好閱讀,性能好

11. if<=3,別用if了,用3元表達(dá)式吧

12. if==1,if改&&


if(a==1)a=2
        改
        a==1&&(a=2);
13.計(jì)算元素位置,while()offsetParent

這個方式是老方式了,現(xiàn)在的瀏覽器ie6以上,ff3.1以上,chrome,opera(我只測了最新的)都支持這個el.getBoundingClientRect返回一個對像,分別是top,left,right,bottom的值

14.正則的查找沒有indexOf快


var s= sdfsdfsdfAAAsdfdsfs;
for(var i=0;i<1000;i++){
        s.indexOf(AAA)
}
比這個快


var s= sdfsdfsdfAAAsdfdsfs;
for(var i=0;i<1000;i++){
        /AAA/.test(s)
}
15.在正則中多用非捕獲(?:)這樣快

16.設(shè)置某個元素的style時用cssText簡單些


el.style.cssText +=";postion:absolute;"
(注意:position前;不能去了,因?yàn)閕e沒有這個;position認(rèn)不出來了就,比的瀏覽器沒這個毛病)

17.在new 時,沒有參數(shù)時函數(shù)名后邊的括號可以去了


new fn()==>new fn
new Image()==>new Image

   

發(fā)表評論(共0條評論)
請自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī),評論內(nèi)容只代表網(wǎng)友觀點(diǎn),發(fā)表審核后顯示!

版權(quán)聲明:

1 本站所有資源(含游戲)均是軟件作者、開發(fā)商投稿,任何涉及商業(yè)盈利目的均不得使用,否則產(chǎn)生的一切后果將由您自己承擔(dān)!

2 本站將不對任何資源負(fù)法律責(zé)任,所有資源請?jiān)谙螺d后24小時內(nèi)刪除。

3 若有關(guān)在線投稿、無法下載等問題,請與本站客服人員聯(lián)系。

4 如侵犯了您的版權(quán)、商標(biāo)等,請立刻聯(lián)系我們并具體說明情況后,本站將盡快處理刪除,聯(lián)系QQ:2499894784

返回頂部