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

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > JavaScript 中的作用域
如何正確的使用 id 和 class 回到列表 重新認識 button 標(biāo)簽
 JavaScript 中的作用域

作者:Realazy 時間: 2007-07-26 文檔類型:翻譯 來自:Realazy

第 1 頁 JavaScript 中的作用域 [1]
第 2 頁 JavaScript 中的作用域 [2]
第 3 頁 JavaScript 中的作用域 [3]
第 4 頁 JavaScript 中的作用域 [4]

this? 那是蝦米?

每一個運行上下文除了建立一個作用域鏈外,還峁┮桓雒猼his的關(guān)鍵字。它的普遍用法是,this作為一個獨特的功能,為鄰里們提供一個可訪問到它的途徑。但總是依賴于這個行為并不可靠:取決于我們?nèi)绾芜M入一個特定鄰居的具體情況,this表示的完全可能是其他東西。事實上,我們?nèi)绾芜M去鄰居家本身,通常恰恰就是this所指。有四種情形值得特別注意:

  1. 呼叫對象的方法

    在經(jīng)典的面向?qū)ο缶幊讨校覀冃枰R別和引用當(dāng)前對象。this極好地扮演了這個角色,為我們的對象提供了自我查找的能力,并指向它們本身的屬性。

    <script type="text/javascript">
      var deep_thought = {
       the_answer: 42,
       ask_question: function () {
        return this.the_answer;
       }
      };

      var the_meaning = deep_thought.ask_question();
    </script>

    這個例子建立了一個名為deep_thought的對象,設(shè)置其屬性 the_answer為42,并創(chuàng)建了一個名為ask_question 的方法(method)。當(dāng)deep_thought.ask_question()執(zhí)行時, JavaScript為函數(shù)的呼叫建立了一個運行上下文,通過”.“運算符把this指向被引用的對象,在此是deep_thought這個對象。之后這個方法就可以通過this在鏡子中找到它自身的屬性,返回保存在 this.the_answer中的值:42。

  2. 構(gòu)造函數(shù)

    類似地,當(dāng)定義一個作為構(gòu)造器的使用new關(guān)鍵字的函數(shù)時,this可以用來引用剛創(chuàng)建的對象。讓我們重寫一個能反映這個情形的例子:

    <script type="text/javascript">
      function BigComputer(answer) {
       this.the_answer = answer;
       this.ask_question = function () {
        return this.the_answer;
       }
      }

      var deep_thought = new BigComputer(42);
      var the_meaning = deep_thought.ask_question();
    </script>

    我們編寫一個函數(shù)來創(chuàng)建BigComputer對象,而不是直白地創(chuàng)建 deep_thought對象,并通過new關(guān)鍵字實例化deep_thought為一個實例變量。當(dāng)new BigComputer()被執(zhí)行,后臺透明地創(chuàng)建了一個嶄新的對象。呼叫BigComputer后,它的this關(guān)鍵字被設(shè)置為指向新對象的引用。這個函數(shù)可以在this上設(shè)置屬性和方法,最終它會在BigComputer執(zhí)行后透明地返回。

    盡管如此,需要注意的是,那個deep_thought.the_question()依然可以像從前一樣執(zhí)行。那這里發(fā)生了什么事?為何this在the_question內(nèi)與BigComputer內(nèi)會有所不同?簡單地說,我們是通過new進入BigComputer的,所以this表示“新(new)的對象”。在另一方面,我們通過 deep_thought進入the_question,所以當(dāng)我們執(zhí)行該方法時,this表示 “deep_thought所引用的對象”。this并不像其他的變量一樣從作用域鏈中讀取,而是在上下文的基礎(chǔ)上,在上下文中重置。

  3. 函數(shù)呼叫
    假如沒有任何相關(guān)對象的奇幻東西,我們只是呼叫一個普通的、常見的函數(shù),在這種情形下this表示的又是什么呢?

    <script type="text/javascript">
      function test_this() {
       return this;
      }
      var i_wonder_what_this_is = test_this();
    </script>


    在這樣的場合,我們并不通過new來提供上下文,也不會以某種對象形式在背后偷偷提供上下文。在此, this默認下盡可能引用最全局的東西:對于網(wǎng)頁來說,這就是 window對象。

  4. 事件處理函數(shù)

    比普通函數(shù)的呼叫更復(fù)雜的狀況,先假設(shè)我們使用函數(shù)去處理的是一個onclick事件。當(dāng)事件觸發(fā)我們的函數(shù)運行,此處的this表示的是什么呢?不湊巧,這個問題不會有簡單的答案。

    如果我們寫的是行內(nèi)(inline)事件處理函數(shù),this引用的是全局window對象:

    <script type="text/javascript">
      function click_handler() {
       alert(this); // 彈出 window 對象
      }
    </script>
     ...
    <button id='thebutton' onclick='click_handler()'>Click me!</button>


    但是,如果我們通過JavaScript來添加事件處理函數(shù),this引用的是生成該事件的DOM元素。(注意:此處的事件處理非常簡潔和易于閱讀,但其他的就別有洞天了。請使用 真正的addEvent函數(shù) 取而代之):

    <script type="text/javascript">
      function click_handler() {
       alert(this); // 彈出按鈕的DOM節(jié)點
      }

      function addhandler() {
       document.getElementById('thebutton').onclick = click_handler;
      }

      window.onload = addhandler;
    </script>
     ...
    <button id='thebutton'>Click me!</button>

出處:Realazy
責(zé)任編輯:moby

上一頁 JavaScript 中的作用域 [1] 下一頁 JavaScript 中的作用域 [3]

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

相關(guān)文章 更多相關(guān)鏈接
如何快速的呈現(xiàn)我們的網(wǎng)頁
用javascript 轉(zhuǎn)換外部鏈接樣式
用javascript實現(xiàn)select的美化
JavaScript 的事件冒泡 demo 
面向?qū)ο蟮?Javascript
作者文章 更多作者文章
設(shè)計五原則
標(biāo)準的 語義的 非侵入的頁簽切換
未知高度的非表格垂直對齊
JavaScript 的事件冒泡 demo 
面向任務(wù),還是面向信息?
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準 用戶體驗 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
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/41個記錄/頁 轉(zhuǎn)到 頁 共4個記錄

藍色理想版權(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