中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小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]

變量作用域

JavaScript中的許多問題都來自于變量作用域:要么認為局部變量是全局的,要么用函數(shù)中的局部變量覆蓋了全局變量。為了避免這些問題,最佳方案是根本沒有任何全局變量。但是,如果你有一堆,那么你應(yīng)該知道這些陷阱。

不用var關(guān)鍵字聲明的變量是全局的。記住使用var關(guān)鍵字聲明變量,防止變量具有全局作用域。在下面例子中,在函數(shù)中聲明的變量具有全局變量,因為沒有使用var關(guān)鍵字聲明:

anonymousFuntion1 = function(){
 globalvar = 'global scope'; //全局聲明,因為“var”遺漏了
 return localvar;
}();
alert(globalvar); //彈出“global scope”,因為函數(shù)中的變量是全局聲明

anonymousFuntion2 = function(){
 var localvar = 'local scope'; //使用“var”局部聲明
 return localvar;
}();
alert(localvar); //錯誤 “l(fā)ocalvar未定義”。沒有全局定義localvar

作為參數(shù)引進到函數(shù)的變量名是局部的。如果參數(shù)名也是一個全局變量的名字,像參數(shù)變量一樣有局部作用域,這沒有沖突。如果你想在函數(shù)中改變一個全局變量,這個函數(shù)有一個參數(shù)復(fù)制于這個全局變量名,記住所有全局變臉都是window對象的屬性。

var myscope = "global";
function showScope(myscope){
 return myscope; //局部作用域,即使有一個相同名字的全局變量
}
alert(showScope('local'));

function globalScope(myscope){
 myscope = window.myscope; //全局作用域
 return myscope;
}
alert(globalScope(’local’));

你甚至可以在循環(huán)中聲明變量:

for(var i = 0; i < myarray.length; i++){}

覆蓋函數(shù)/重載函數(shù)

當你不止一次的聲明一個函數(shù)時,這個函數(shù)的最后一次聲明將覆蓋掉該函數(shù)的所有前面版本且不會拋出任何錯誤或警告。這不同于其他的編程語言,像Java,你能用相同的名字有多重函數(shù),只要它們有不同的參數(shù):調(diào)用函數(shù)重載。在JavaScript中沒有重載。這使得不能在代碼中使用JavaScript核心部分的名字極其重要。也要當心包含的多個JavaScript文件,像一個包含的腳本文件可能覆蓋另一個腳本文件中的函數(shù)。請使用匿名函數(shù)和名字空間。

(function(){
 // creation of my namespace 創(chuàng)建我的名字空間
 if(!window.MYNAMESPACE) {
  window['MYNAMESPACE'] = {};
 }
 //如果名字空間不存在,就創(chuàng)建它
 //這個函數(shù)僅能在匿名函數(shù)中訪問
 function myFunction(var1, var2){
  //內(nèi)部的函數(shù)代碼在這兒
 }
 // 把內(nèi)部函數(shù)連接到名字空間上,使它通過使用名字空間能訪問匿名函數(shù)的外面
 window['MYNAMESPACE']['myFunction'] = myFunction;
})(); // 圓括號 = 立即執(zhí)行
// 包含所有代碼的圓括號使函數(shù)匿名

這個例子正式為了實現(xiàn)解決上一個陷阱“變量作用域”的最佳方案。匿名函數(shù)詳細內(nèi)容請看《Javascript的匿名函數(shù)》。YUI整個庫只有YAHOO和YAHOO_config兩個全局變量,它正是大量應(yīng)用匿名函數(shù)和命名空間的方法來實現(xiàn),具體請看《Javascript的一種模塊模式》

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

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

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

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

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

轉(zhuǎn)載要求:轉(zhuǎ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