談談javascript的範圍鏈和this

來源:互聯網
上載者:User

範圍和this絕對是javascript中最容易讓人栽跟頭的地方之一,閑話少說,先問題個問題?

var a = {  b: 1,  c: function() {    alert(this.b.toString());  }}a.c();b = a.cb();

思考下,再看後面的答案。是不是覺得是:

1
1

公布正確答案

1function () {    console.log(this.b.toString());}

再看下面這段程式:

var b;var a = {  b: 1,  c: function() {    alert(b);  }}a.c();b = a.cb();

正確答案:

undefined
[Function]

ps:如果你一下子就能答出兩道題正確答案,說明你已經比較掌握this的使用,本文可能並不適合你,可以不需要再看接下來的內容

言歸正傳,為什麼是這樣的運行結果呢?

主要請記住重要的這麼幾點:

* JavaScript中的函數運行在它們被定義的範圍裡,而不是它們被執行的範圍裡

* 那就是this指的是,調用函數的那個對象

第一道題中調用b()時,this已經指向全域,所以this.b就是一個函數

第二道題中a.c()和b()得到的是範圍鏈最外層的全域變數b

 

參考文章:

範圍鏈:http://www.laruence.com/2009/05/28/863.html

this用法:http://www.ruanyifeng.com/blog/2010/04/using_this_keyword_in_javascript.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.