欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS變量及其作用域

 更新時(shí)間:2017年03月29日 14:54:30   作者:liujian_laohan  
本文主要介紹了JS變量及其作用域的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧

1、 變量及其作用域:變量分為“全局變量”和“局部變量”,“全局變量”申明在函數(shù)外部,可供所有函數(shù)使用,而“局部變量”申明在函數(shù)體內(nèi)部,只能在定義該變量的函數(shù)體內(nèi)使用。

(備注:在申明變量時(shí)沒(méi)有var關(guān)鍵字,而是直接賦值的變量均為全局變量)

<script type="text/javascript">
  function main() {  
    n = 10;//這里的n為全局變量,可以被外部直接使用
  }
  main();
  alert(n);
</script>

2、 在函數(shù)體內(nèi),局部變量的優(yōu)先級(jí)高于全局變量。

<script type="text/javascript">
  //網(wǎng)上看到的我認(rèn)為很有代表性的一個(gè)例子,在函數(shù)體外部和內(nèi)部都申明了相同名字的變量,變量的作用域問(wèn)題,例子如下:
  var n = 1;
  function test() {
    alert(n); //這里的a并不是全局變量,原因是函數(shù)體第四行申明了一個(gè)相同重名的局部變
         //量a,如果把第四行a的申明注釋掉,那么這里的a顯示1,為全局變量。所以得
         //出結(jié)論:全局變量a被局部變量a覆蓋了。
         //說(shuō)明了JS函數(shù)在test()在執(zhí)行前,函數(shù)體內(nèi)的變量a都指向了局部變量,但本
         //行輸出的a在執(zhí)行過(guò)程中還沒(méi)有被賦值,所以顯示undefined。
    n = 2;
    alert(n);
    var n; //本行申明局部變量a
    alert(n);
  }
    test();
    alert(n);
</script>

按照我的理解,上面例子最后輸出的答案應(yīng)該是:1 2 2 1;但是正確的答案是:undefined 2 2 1; 原因就是函數(shù)體外部和內(nèi)部都申明了相同名字的變量時(shí),局部變量覆蓋了全局變量。

3、 外部怎么讀取函數(shù)體內(nèi)部的局部變量呢?

一般來(lái)說(shuō),只有函數(shù)體內(nèi)部可以直接得到外部的全局變量,但是外部要得到函數(shù)體內(nèi)部的局部變量是不行的。但是,通過(guò)在函數(shù)體內(nèi)部再定義一個(gè)函數(shù)返回局部變量,再?gòu)耐獠空{(diào)用函數(shù)就能實(shí)現(xiàn)了。

<script type="text/javascript">
  function f1() {    
    var n = 10;    
    function f2() {//在f1()內(nèi)部再定義f2(),通過(guò)f2()訪問(wèn)f1()中的局部變量      
      alert(n);    
    }    
    return f2;//返回f1()局部變量n
  }  
  var result = f1(); //在外部調(diào)用f1()函數(shù),就能獲取局部變量n的值
  result(); // 10,即為n的值
</script>

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • Javascript編程中幾種繼承方式比較分析

    Javascript編程中幾種繼承方式比較分析

    這篇文章主要介紹了Javascript編程中幾種繼承方式比較分析,較為詳細(xì)的分析了JavaScript繼承的原理并對(duì)比分析了幾種繼承方式的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-11-11
  • 分享一款超好用的JavaScript 打包壓縮工具

    分享一款超好用的JavaScript 打包壓縮工具

    這篇文章主要介紹了寫一個(gè)飛快的 JavaScript 打包壓縮工具,非常好用,本文給大家分享實(shí)現(xiàn)思路,需要的朋友可以參考下
    2020-04-04
  • JS與CSS3實(shí)現(xiàn)圖片響應(yīng)鼠標(biāo)移動(dòng)放大效果示例

    JS與CSS3實(shí)現(xiàn)圖片響應(yīng)鼠標(biāo)移動(dòng)放大效果示例

    這篇文章主要介紹了JS與CSS3實(shí)現(xiàn)圖片響應(yīng)鼠標(biāo)移動(dòng)放大效果,結(jié)合實(shí)例形式分析了javascript與css3響應(yīng)鼠標(biāo)事件動(dòng)態(tài)修改頁(yè)面元素屬性實(shí)現(xiàn)圖片放大效果相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • 用js的for循環(huán)獲取radio選中的值

    用js的for循環(huán)獲取radio選中的值

    獲取radio選中值的方法有很多,在本文為大家介紹的是使用for循環(huán)來(lái)實(shí)現(xiàn),具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考下
    2013-10-10
  • Bootstrap列表組學(xué)習(xí)使用

    Bootstrap列表組學(xué)習(xí)使用

    這篇文章主要為大家詳細(xì)介紹了Bootstrap列表組的學(xué)習(xí)使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Javascript blur與click沖突解決辦法

    Javascript blur與click沖突解決辦法

    這篇文章主要介紹了Javascript blur與click沖突解決辦法的相關(guān)資料,在開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)遇到blur與click 沖突的情況,這里舉了幾個(gè)例子,和解決辦法,需要的朋友可以參考下
    2017-01-01
  • 5秒后跳轉(zhuǎn)到另一個(gè)頁(yè)面的js代碼

    5秒后跳轉(zhuǎn)到另一個(gè)頁(yè)面的js代碼

    跳轉(zhuǎn)到另一個(gè)頁(yè)面的方法有很多,在本文將為大家詳細(xì)介紹下js中如何實(shí)現(xiàn)5秒后跳轉(zhuǎn)到另一個(gè)頁(yè)面,感興趣的朋友可不要錯(cuò)過(guò)
    2013-10-10
  • 解決window.history.back()返回上一頁(yè)有時(shí)候需要點(diǎn)擊多次問(wèn)題

    解決window.history.back()返回上一頁(yè)有時(shí)候需要點(diǎn)擊多次問(wèn)題

    這篇文章主要介紹了解決window.history.back()返回上一頁(yè)有時(shí)候需要點(diǎn)擊多次問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • pace.js頁(yè)面加載進(jìn)度條插件

    pace.js頁(yè)面加載進(jìn)度條插件

    在頁(yè)面中引入 Pace.js 和您所選擇主題的 CSS 文件,就可以讓你的頁(yè)面擁有漂亮的加載進(jìn)度和 Ajax 導(dǎo)航效果。不需要掛接到任何代碼,自動(dòng)檢測(cè)進(jìn)展。您可以選擇顏色和多種效果,有簡(jiǎn)約,閃光燈,MAC OSX,左側(cè)填充,頂部填充,計(jì)數(shù)器和彈跳等等。
    2015-09-09
  • 解決使用layui對(duì)select append元素?zé)o效或者未及時(shí)更新的問(wèn)題

    解決使用layui對(duì)select append元素?zé)o效或者未及時(shí)更新的問(wèn)題

    今天小編就為大家分享一篇解決使用layui對(duì)select append元素?zé)o效或者未及時(shí)更新的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09

最新評(píng)論