成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript:Scope(域)的基本指南

voidking / 1188人閱讀

摘要:變量范圍有助于減少阻止這種情況發(fā)生。但是,在函數(shù)之外調(diào)用將導(dǎo)致由于局部變量只能在其函數(shù)中訪問,因此可以在不同的函數(shù)中使用相同的變量名稱詞法作用域?qū)W習(xí)詞法作用域也很重要。局部變量在函數(shù)啟動(dòng)時(shí)創(chuàng)建,并在函數(shù)結(jié)束時(shí)刪除。

Scope決定了代碼中變量,函數(shù)和對象的可見性。在這里了解所有細(xì)節(jié)。

Scope是JavaScript和編程的一個(gè)重要方面。Scope限制了整個(gè)代碼中變量,函數(shù)和對象的可見性以及可用性。

這帶來了很多好處,其中包括:

安全 - 變量只能在需要的地方訪問。

減少變量名空間沖突 - 當(dāng)兩個(gè)或更多變量共享一個(gè)通用名稱時(shí),會發(fā)生變量名沖突。變量范圍有助于減少阻止這種情況發(fā)生。

*

在最基本的層面上,JavaScript有兩種類型的范圍:

Global Scope(全局作用域)

Local Scope(局部作用域)

全局作用域

當(dāng)你開始用JavaScript編寫代碼時(shí),你就已經(jīng)在全局范圍內(nèi)。任何在全局范圍內(nèi)編寫的東西都可以在JavaScript代碼中的任何地方訪問

var cat = "Jerry";
function localScopeExample(){
  // LOCAL SCOPE
  console.log(cat); // Jerry
}
// GLOBAL SCOPE
console.log(cat); // Jerry
局部作用域

局部作用域稍微復(fù)雜一點(diǎn)。局部作用域變量只能在局部作用域(它們被定義的地方)中可見和可訪問。您可以將局部作用域視為您在全局范圍內(nèi)創(chuàng)建的任何新范圍。

一個(gè)簡單的例子就是在使用函數(shù)時(shí)。用JavaScript編寫的每個(gè)函數(shù)都會創(chuàng)建一個(gè)新的局部作用域。這些局部作用域的變量只能在它們定義的函數(shù)中訪問。

我們來看一個(gè)例子。我們將創(chuàng)建一個(gè)函數(shù)并在該函數(shù)中聲明變量cat。貓可以訪問并且可以在該功能的任何地方使用。但是,在函數(shù)之外調(diào)用cat將導(dǎo)致Uncaught ReferenceError:

function localScopeExample(){
  // LOCAL SCOPE
  var cat = "Jerry";
  console.log(cat); // Jerry
}
// GLOBAL SCOPE
console.log(cat); // Uncaught ReferenceError: cat is not defined

由于局部變量只能在其函數(shù)中訪問,因此可以在_不同的函數(shù)中使用相同的變量名稱_:

function func1(){
  var cat = "Jerry";
  console.log(cat); // Jerry
}
function func2(){
  var cat = "Tom";
  console.log(cat); // Tom
}
詞法作用域

學(xué)習(xí)詞法作用域也很重要。詞法作用域(也稱為靜態(tài)作用域)是內(nèi)部函數(shù)訪問外部函數(shù)范圍的能力。

我們來看一個(gè)例子。在下面的代碼中,我們定義了兩個(gè)函數(shù) - func1在全局范圍內(nèi),func2func1范圍內(nèi)聲明。由于詞匯范圍的限制,您可以在_范圍2_中訪問_全局作用域_和_范圍1_中的所有內(nèi)容:

// GLOBAL SCOPE
var dog = "Lewis";
function func1(){
  // SCOPE 1
  var cat = "Jerry";
  var func2 = function(){
    // SCOPE 2
    console.log(cat); // Jerry
    console.log(dog); // Lewis
  }
}
塊級作用域

使用var時(shí),變量既可以是全局作用域,也可以局部作用于定義它的函數(shù)。塊級作用域如iffor,while{}var 沒有影響。

let & const,另一方面,它們被限定在它們所定義的區(qū)塊內(nèi)。我們來看一個(gè)例子:

let x = 1;
{
  let x = 2;
  console.log(x); // 2
}
console.log(x); // 1

正如你在上面看到的那樣,簡單地使用括號來創(chuàng)建一個(gè)代碼塊將在本地范圍內(nèi)在該塊內(nèi)聲明的任何變量。相同的概念適用于其他塊范圍:

let x = 1;
if (x !== 2) {
  let x = 2;
  console.log(x); // 2
}
console.log(x); // 1

但要小心。如果您不小心重新聲明具有相同塊范圍的相同變量,則會出現(xiàn)錯(cuò)誤:

{
  let x = 1;
  let x = 2;
}
Uncaught SyntaxError: Identifier "x" has already been declared
關(guān)鍵要點(diǎn):

全局范圍的持續(xù)時(shí)間與系統(tǒng)一樣長。

局部變量在函數(shù)啟動(dòng)時(shí)創(chuàng)建,并在函數(shù)結(jié)束時(shí)刪除。

詞法作用域允許內(nèi)部函數(shù)訪問其外部函數(shù)的作用域

constlet是塊范圍變量。塊范圍不適用于var。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52334.html

相關(guān)文章

  • JavaScriptScope基本指南

    摘要:變量范圍有助于減少阻止這種情況發(fā)生。但是,在函數(shù)之外調(diào)用將導(dǎo)致由于局部變量只能在其函數(shù)中訪問,因此可以在不同的函數(shù)中使用相同的變量名稱詞法作用域?qū)W習(xí)詞法作用域也很重要。局部變量在函數(shù)啟動(dòng)時(shí)創(chuàng)建,并在函數(shù)結(jié)束時(shí)刪除。 Scope決定了代碼中變量,函數(shù)和對象的可見性。在這里了解所有細(xì)節(jié)。 showImg(https://segmentfault.com/img/remote/1460000...

    Heier 評論0 收藏0
  • JavaScriptScope基本指南

    摘要:變量范圍有助于減少阻止這種情況發(fā)生。但是,在函數(shù)之外調(diào)用將導(dǎo)致由于局部變量只能在其函數(shù)中訪問,因此可以在不同的函數(shù)中使用相同的變量名稱詞法作用域?qū)W習(xí)詞法作用域也很重要。局部變量在函數(shù)啟動(dòng)時(shí)創(chuàng)建,并在函數(shù)結(jié)束時(shí)刪除。 Scope決定了代碼中變量,函數(shù)和對象的可見性。在這里了解所有細(xì)節(jié)。 showImg(https://segmentfault.com/img/remote/1460000...

    techstay 評論0 收藏0
  • JavaScript深入之詞法作用和動(dòng)態(tài)作用

    摘要:作用域作用域是指程序源代碼中定義變量的區(qū)域。采用詞法作用域,也就是靜態(tài)作用域。而與詞法作用域相對的是動(dòng)態(tài)作用域,函數(shù)的作用域是在函數(shù)調(diào)用的時(shí)候才決定的。前面我們已經(jīng)說了,采用的是靜態(tài)作用域,所以這個(gè)例子的結(jié)果是。 JavaScript深入系列的第二篇,JavaScript采用詞法作用域,什么語言采用了動(dòng)態(tài)作用域?兩者的區(qū)別又是什么?還有一個(gè)略難的思考題,快來看看吧。 作用域 作用域是指...

    gclove 評論0 收藏0
  • JavaScript閉包

    摘要:閉包引起的內(nèi)存泄漏總結(jié)從理論的角度將由于作用域鏈的特性中所有函數(shù)都是閉包但是從應(yīng)用的角度來說只有當(dāng)函數(shù)以返回值返回或者當(dāng)函數(shù)以參數(shù)形式使用或者當(dāng)函數(shù)中自由變量在函數(shù)外被引用時(shí)才能成為明確意義上的閉包。 文章同步到github js的閉包概念幾乎是任何面試官都會問的問題,最近把閉包這塊的概念梳理了一下,記錄成以下文章。 什么是閉包 我先列出一些官方及經(jīng)典書籍等書中給出的概念,這些概念雖然...

    HmyBmny 評論0 收藏0
  • 深入學(xué)習(xí)js之——詞法作用和動(dòng)態(tài)作用

    摘要:在中的應(yīng)用采用詞法作用域,也就是靜態(tài)作用域。那什么又是詞法作用域或者靜態(tài)作用域呢請繼續(xù)往下看靜態(tài)作用域與動(dòng)態(tài)作用域因?yàn)椴捎玫氖窃~法作用域函數(shù)的作用域在函數(shù)定義的時(shí)候就決定了。 開篇 當(dāng)我們在開始學(xué)習(xí)任何一門語言的時(shí)候,都會接觸到變量的概念,變量的出現(xiàn)其實(shí)是為了解決一個(gè)問題,為的是存儲某些值,進(jìn)而,存儲某些值的目的是為了在之后對這個(gè)值進(jìn)行訪問或者修改,正是這種存儲和訪問變量的能力將狀態(tài)給...

    shiweifu 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<