中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > JavaScript的陷阱
基于display:table的CSS布局 回到列表 用javascript修復(fù)瀏覽器中頭痛問題
 JavaScript的陷阱

作者:秦歌 時間: 2008-10-28 文檔類型:翻譯 來自:藍色理想

第 1 頁 JavaScript的陷阱 [1]
第 2 頁 JavaScript的陷阱 [2]
第 3 頁 JavaScript的陷阱 [3]
第 4 頁 JavaScript的陷阱 [4]
第 5 頁 JavaScript的陷阱 [5]

遺漏的參數(shù)

當(dāng)給函數(shù)增加一個參數(shù)時,一個常見的錯誤是忘記更新這個函數(shù)的所有調(diào)用。如果你需要在已經(jīng)被調(diào)用的函數(shù)中增加一個參數(shù)來處理一個特殊情況下的調(diào)用,請給這個函數(shù)中的這個參數(shù)設(shè)置默認(rèn)值,以防萬一在眾多腳本中的眾多調(diào)用中的一個忘記更新。

function addressFunction(address, city, state, country){
 country = country || “US”; //如果沒有傳入country,假設(shè) “US”
 span>//剩下代碼
}

你也能通過獲取arguments來解決。但是在這篇文章我們的注意力在陷阱上。同時在《Javascript風(fēng)格要素(2)》也介紹了||巧妙應(yīng)用。

for語句

在JavaScript中“for”循環(huán)將遍歷所有的對象屬性(attribute),包括方法和屬性(property)。決不能使用for in來遍歷數(shù)組:僅在當(dāng)需要遍歷對象屬性和方法時才使用for in。

  1. for(var myVar in myObject)用一個指定變量無任何規(guī)律地遍歷對象的所有屬性。如果for/in循環(huán)的主體刪除了一個還沒有枚舉出的屬性,那么該屬性就不在枚舉。如果循環(huán)主體定義了新屬性,那么循環(huán)是否枚舉該屬性則是由JavaScript的實現(xiàn)決定。
  2. for(var 1=0; i < myArray.length; i++)會遍歷完一個數(shù)組的所有元素。

為了解決這個問題,大體上你可以對對象使用 for … in,對數(shù)組使用for循環(huán):

listItems = document.getElementsByTagName('li');
for (var listitem in listItems){
 //這里將遍歷這個對象的所有屬性和方法,包括原生的方法和屬性,但不遍歷這個數(shù)組:出錯了!
}
//因為你要循環(huán)的是數(shù)組對象,所用for循環(huán)
for ( var i = 0; i < listItems.length; i++) {
 //這是真正你想要的
}

對象的有些屬性以相同的方式標(biāo)記成只讀的、永久的或不可列舉的,這些屬性for/in無法枚舉。實際上,for/in循環(huán)會遍歷所有對象的所有可能屬性,包括函數(shù)和原型中的屬性。所有修改原型屬性可能對for/in循環(huán)帶來致命的危害,所以需要采用hasOwnProperty和typeof做一些必要的過濾,最好是用for來代替for/in。

switch語句

Estelle Weyl寫了一篇 switch statement quirks ,其要點是:

  1. 沒有數(shù)據(jù)類型轉(zhuǎn)換
  2. 一個匹配,所有的表達式都將執(zhí)行直到后面的break或return語句執(zhí)行
  3. 你可以對一個單獨語句塊使用多個case從句

undefined ≠ null

null是一個對象,undefined是一個屬性、方法或變量。存在null是因為對象被定義。如果對象沒有被定義,而測試它是否是null,但因為沒有被定義,它無法測試到,而且會拋出錯誤。

if(myObject !== null  && typeof(myObject) !== 'undefined') {
 //如果myObject是undefined,它不能測試是否為null,而且還會拋出錯誤
}
if(typeof(myObject) !== 'undefined' && myObject !== null) {
 //處理myObject的代碼
}

Harish Mallipeddi 對undefined和null有一個說明。

事件處理陷阱

剛接觸事件處理時最常見的寫法就是類似:

window.onclick = MyOnClickMethod

這種做法不僅非常容易出現(xiàn)后面的window.onclick事件覆蓋掉前面的事件,還可能導(dǎo)致大名頂頂?shù)腎E內(nèi)存泄露問題。為了解決類似問題,4年前 Simon Willison 就寫出了很流行的addLoadEvent():

function addLoadEvent(func) {
 var oldonload = window.onload;
 if (typeof window.onload != 'function') {
  window.onload = func;
 }else {
  window.onload = function() {
   oldonload();
   unc();
  }
 }
}
addEvent(window,'load',func1,false);
addEvent(window,'load',func2,false);
addEvent(window,'load',func3,false);

當(dāng)然在JavaScript庫盛行的現(xiàn)在,使用封裝好的事件處理機制是一個很好的選擇,比如在YUI中就可以這樣寫:

YAHOO.util.Event.addListener(window, "click", MyOnClickMethod);

本文鏈接:http://www.95time.cn/tech/web/2008/6254.asp 

出處:藍色理想
責(zé)任編輯:bluehearts

上一頁 JavaScript的陷阱 [4] 下一頁

◎進入論壇網(wǎng)頁制作WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
用javascript修復(fù)瀏覽器中頭痛問題
Javascript利用閉包循環(huán)綁定事件
理解"漸進增強"
精通JavaScript+jQuery
Javascript——淺析注冊事件
作者文章 更多作者文章
關(guān)于基于字體大小(em)的設(shè)計
Javascript的匿名函數(shù)
Firefox2中輸入框丟失光標(biāo)bug
Javascript風(fēng)格要素 Ⅱ
Firefox 2和3在windows下的共存
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:5/51個記錄/頁 轉(zhuǎn)到 頁 共5個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2