亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中常見陷阱小結(jié)

 更新時間:2010年04月27日 17:03:38   作者:  
JavaScript中常見陷阱,都是一些實際應(yīng)用中,需要注意的地方,需要的朋友可以參考下。
你所創(chuàng)建的所有函數(shù)都是區(qū)分大小寫的
單引號('字符串')和雙引號("字符串")在JavaScript中沒有特殊的區(qū)別,都可以用來創(chuàng)建字符串.但作為一般原則,大多數(shù)WEB開發(fā)者都選擇使用單引號 而不是雙引號,因為XHTML規(guī)范要求所有XHTML屬性值都必須使用雙引號括起來.

JavaScript不支持重載,在JavaScript中,腳本在執(zhí)行時不會顧及函數(shù)定義時的參數(shù),而是直接使用在作用域鏈中最后定義的那個函數(shù)。這意味著,相同名稱的函數(shù)永遠(yuǎn)只存在一個實例


閉包是與作用域相關(guān)的一個概念,它指的是內(nèi)部函數(shù)即使在外部函數(shù)執(zhí)行完成并終止后,依然可以訪問其外部函數(shù)的屬性。當(dāng)引用一個變量或方法時,JavaScript會沿著由對象執(zhí)行路徑構(gòu)成使用域鏈對使用域進(jìn)行解析,查找變量最近定義的值,一旦找到即使用該值。function initAnchors(event){
復(fù)制代碼 代碼如下:

  for (var i=1; i <=3; i++){
    var anchor = document.GetElementById('anchor' + i);
    anchor.attachEvent('onclick', function() { 
    alert('my id is anchor' + i);
    });
  }
}

假設(shè)頁面中有三個A元素,ID分別為anchor1到anchor3,程序為三個A元素注冊onclick事件,單擊第個A元素顯示"my id is anchorX",但實際運行情況卻不是這樣,單擊每個A元素都顯示"my id is anchor4"。為什么會這樣呢,因為i的值實際上是在單擊事件發(fā)生時才從使用域鏈中取得的,當(dāng)單擊事件發(fā)生時,initAnchors()已執(zhí)行完畢,此時i的值等于4。解決方法可以按如下
復(fù)制代碼 代碼如下:

function registerAnchorListner(anchor,i){
  anchor.attachEvent('onclick', function() { 
    alert('my id is anchor' + i);
  }  
}
function initAnchors(event){
  for (var i=1; i <=3; i++){
    var anchor = document.GetElementById('anchor' + i);
    registerAnchorListner(anchor,i);

  }

}

var anchor = document.GetElementById('anchor' + i);
anchor.attachEvent('onclick', function() {
alert('my id is anchor' + i);



});



迭代對象,在編寫腳本時經(jīng)常使用到迭代,如下:
復(fù)制代碼 代碼如下:

var list = [1,2,3,4];
for(var i = 0;i < list.length; i++){
  alert(list);
}

另一種可供選擇的迭代方法是使用for循環(huán)遍歷位于(in)list中的每個屬性:
復(fù)制代碼 代碼如下:

for(var i in list){
  alert(list);
}

此時,得到的是與使用前一迭代方法相同的結(jié)果,因為list是一個Array對象。

但是,當(dāng)使用for(var i in item)方法操縱類似數(shù)組而又不是數(shù)組的對象時一定要格外小心,如下
復(fù)制代碼 代碼如下:

var all=document.getElementsByTagName('*');
for(var i in all){
  //對照all元素進(jìn)行某些操作
}

在這次的迭代過程中,i的值會分別等于length、item和namedItem,而這很可能會導(dǎo)致代碼中出現(xiàn)意外錯誤。在某些情況下,可以使用對象的hasOwnProperty()方法來避免這個問題。如果對象的屬性或方法是非繼承的,那么hasOwnProperty()方法返回true。即這里的檢查不涉及從其它對象繼承的屬性和方法,只會檢查在特定對象自身中直接創(chuàng)建的屬性,比如分配給數(shù)組的元素。因此,在如果在for循環(huán)中使用這種檢查,那么循環(huán)將會跳過length這樣屬性,因為length不是數(shù)組all的真系屬性,而是從派生數(shù)組all的NameNodeMap對象中繼承的屬性
復(fù)制代碼 代碼如下:

var all=document.getElementsByTagName('*');
for(var i in all){
  if(!all.hasOwnProperty(i)) continue;
  //對照all元素進(jìn)行某些操作
}

相關(guān)文章

  • js實現(xiàn)仿購物車加減效果

    js實現(xiàn)仿購物車加減效果

    本文主要介紹了js實現(xiàn)仿購物車+ -效果的實例,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • 微信小程序自定義頂部導(dǎo)航組件

    微信小程序自定義頂部導(dǎo)航組件

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義頂部導(dǎo)航組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js中l(wèi)et能否完全替代IIFE

    js中l(wèi)et能否完全替代IIFE

    這篇文章主要介紹了js中l(wèi)et能否完全替代IIFE,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下
    2019-06-06
  • 原生JS實現(xiàn)圖片懶加載(lazyload)實例

    原生JS實現(xiàn)圖片懶加載(lazyload)實例

    圖片懶加載也是比較常見的一種性能優(yōu)化的方法,本篇文章主要介紹了原生JS實現(xiàn)圖片懶加載(lazyload)實例,這里整理了詳細(xì)的代碼,有需要的小伙伴可以參考下
    2017-06-06
  • JavaScript原型與原型鏈深入探究使用方法

    JavaScript原型與原型鏈深入探究使用方法

    js中的原型與原型鏈應(yīng)該是老生常談的話題了,在前端面試中基本都是必問的一個問題,但是很多人還是稀里糊涂的,只知道其表層含義。本文將帶大家深入了解JavaScript中的原型與原型鏈,感興趣的可以學(xué)習(xí)一下
    2022-11-11
  • 詳解微信開發(fā)中snsapi_base和snsapi_userinfo及靜默授權(quán)的實現(xiàn)

    詳解微信開發(fā)中snsapi_base和snsapi_userinfo及靜默授權(quán)的實現(xiàn)

    這篇文章主要介紹了詳解微信開發(fā)中snsapi_base和snsapi_userinfo及靜默授權(quán)的實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • Bootstrap入門書籍之(四)菜單、按鈕及導(dǎo)航

    Bootstrap入門書籍之(四)菜單、按鈕及導(dǎo)航

    這篇文章主要介紹了Bootstrap入門書籍之(四)菜單、按鈕及導(dǎo)航的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • js實現(xiàn)簡單的輪播圖效果

    js實現(xiàn)簡單的輪播圖效果

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)簡單的輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • JavaScript面向?qū)ο缶幊虒崿F(xiàn)模擬

    JavaScript面向?qū)ο缶幊虒崿F(xiàn)模擬

    面向?qū)ο缶幊?Object Oriented Programming)將現(xiàn)實世界中的復(fù)雜關(guān)系抽象成一個個對象,通過對象之間的分工合作對現(xiàn)實世界進(jìn)行模擬
    2022-10-10
  • 5個你不知道的JavaScript字符串處理庫(小結(jié))

    5個你不知道的JavaScript字符串處理庫(小結(jié))

    這篇文章主要介紹了5個你不知道的JavaScript字符串處理庫,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評論