JavaScript 变量作用域分析_javascript技巧
/* 代码1 */
var scope = "global ";
function checkScope() {
var scope = "local ";
function childCheck() {
var scope = "childLocal ";
document.write(scope);
}
function childUndefined() {
document.write(scope);
var scope;
}
function childOverride() {
scope = "childOverride ";
document.write(scope);
}
document.write(scope); //输出"local"
childCheck(); //输出"childLocal"
childUndefined(); //输出"undefined"
childOverride(); //输出"childOverride"
document.write(scope); //输出"childOverride"
}
checkScope(); //输出"local childLocal undefinedchildOverride childOverride"
document.write(scope); //输出"global "
全局作用域与局部作用域
全局(global)变量的作用域是全局的,在Javascript中处处有定义;而函数内部声明的变量是局部(local)变量,其作用域是局部性的,只在函数体内部有定义。对于下面的输出读者应不会感到意外。
/* 代码2 */
var scope = "global";
function checkScope() {
var scope = "local";
document.write(scope);
}
checkScope(); //输出"local"
document.write(scope); //输出"global"
全局变量作用域中使用变量可以不用var语句,但在声明局部变量是一定要使用var语句,否则会视为对全局变量的引用。看下面代码:
/* 代码3 */
var scope = "global";
function checkScope() {
scope = "local";
document.write(scope);
}
checkScope(); //输出"local"
document.write(scope); //输出"local"
没有块作用域
Javascript没有块级作用域,函数中声明的变量在整个函数中都是有定义的。对于下面的代码对于生疏的读者可能颇感意外:
/* 代码4 */
var scope = "global";
function checkScope() {
document.write(scope); //语句4.1
var scope = "local"; //语句4.2
document.write(scope);
}
checkScope(); //输出"undefinedlocal"
由于语句4.1(var scope = "local";)声明的变量在整个checkScope函数作用域内都有效,因此在语句4.2(document.write(scope); )执行的时scope引用的是局部变量,而此时局部变量scope尚未定义,所以输出”undefined”。因此一个好的编程习惯是将所有的变量声明集中起来放在函数的开头。
在了解了上述内容之后,读者再看看代码1应该不会感到困惑了。
对象的属性变量
对象的属性变量比较容易理解,看一下下面的代码读者应该不会感到疑惑。
/* 代码5 */
var scope = "global ";
var obj = new Object();
obj.scope = "object ";
obj.checkScope = function () {
var scope = "loacl ";
document.write(scope); //输出"loacl"
document.write(this.scope); //输出"object"
document.write(window.scope); //输出"global"
}
obj.checkScope(); //输出"loacl object global"

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP中的變數作用域分為局部(函數內)、全域(程式內可存取)、類別範圍(類別實例內可存取)。 global關鍵字可將局部變數宣告為全域變量,static關鍵字可將局部變數宣告為靜態變量,在函數呼叫間保留其值。

在Go中,函數生命週期包括定義、載入、連結、初始化、呼叫和返回;變數作用域分為函數級和區塊級,函數內的變數在內部可見,而區塊內的變數僅在區塊內可見。

Go語言是一種開源的靜態型別語言,它具有簡潔、高效、可靠等特點,越來越受到開發者的喜愛。在Go語言中,變數是程式中最基本的資料儲存形式,變數的作用域和生命週期對於程式的正確性和效率十分重要。變數的作用域指的是變數的可見性和可訪問性,即在何處可以存取這個變數。在Go語言中,變數的作用域分為全域變數和局部變數。全域變數是定義在函數外部的變量,它可以被整個程式任何

在Go中,函數作用域限制變數可見性,限定在變數宣告所在的函數內:在函數內宣告變數:varnametype=value作用域僅限於宣告的程式碼區塊,其他函數或巢狀區塊無法存取這些變數

PHP5.6變數作用域:如何使用static關鍵字定義靜態變數在PHP中,變數的作用域決定了變數的可見性和存取範圍。靜態變數是一種特殊類型的變量,它在函數呼叫之間保持其值不變。在PHP5.6及其上述版本中,可以使用static關鍵字在函數內部和類別方法中定義靜態變數。靜態變數的特點是:靜態變數的作用域僅限於宣告它的函數或方法內部。靜態變數在函數或方法呼叫之

PHP是一種非常流行的網頁開發語言,它允許開發人員在伺服器端創建動態Web應用程式。在PHP中,變數是一種基本的資料結構,用於儲存值和資料。本文將介紹如何在PHP中使用變數。變數的基本語法在PHP中宣告變數的語法非常簡單。變數名以美元符號($)開頭,後面跟著變數名。變數名稱可以是字母、數字或底線的組合,但必須以字母或底線開頭。例如,下面的程式碼聲明了一個名

使用Python的locals()函數取得目前作用域的變數在Python中,locals()是一個內建函數,它可以用來取得目前作用域中的所有變數。這個函數傳回一個字典,其中包含了目前作用域中所有的變數名稱和對應的值。在程式設計過程中,了解目前作用域中的變數是非常有用的,特別是在偵錯階段,可以幫助我們查看變數的值和狀態。而locals()函數正是提供了這樣的功能。下

Golang函數的變數作用域是指函數內部變數的可見性與生命週期。根據變數在函數中的位置和作用域,變數可以分為三種類型:局部變數、參數變數和傳回值變數。詳細介紹:1、局部變量,是在函數內部定義的變量,只能在該函數內部使用,它們的作用域僅限於函數內部,包括函數的所有程式碼區塊和嵌套的程式碼區塊;2、參數變量,是函數接收的輸入參數,可以在函數內部使用,它們的作用域僅限於函數內部等等。
