js中局部變數和全域變數的易混點

來源:互聯網
上載者:User

標籤:document   16px   一個   區別   理解   script   賦值   cti   變數   

1.以下輸出的是:

undefined
局部變數

<script type="application/javascript">
  var scope="全域變數";
  function cal(){
    document.writeln(scope+"<br />");
    var scope="局部變數";                                //(1)處
    document.writeln(scope+"<br />");
  }
  cal();
</script>

2.以上不好理解的話,把函數中的scope改為scope1,則易理解。

原因:函數中的變數為局部變數,整個範圍是函數內。這裡主要是定義變數用var和不用var的區別。

即:1)如果使用var,則程式會強制定義一個新變數

  2)如果不使用,則系統會優先在當前上下文(不僅是上文,還有下文)中搜尋是否存在該變數。只有當該變數不存在時,系統才會重新定義。

所以1中搜尋到了下文定義的scope,但在(1)處並未賦值,故顯示undefined.

 

js中局部變數和全域變數的易混點

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.