首頁 web前端 js教程 javascript权威指南 学习笔记之变量作用域分享_javascript技巧

javascript权威指南 学习笔记之变量作用域分享_javascript技巧

May 16, 2016 pm 06:01 PM
變數作用域

不知道,大家对语言中变量的“声明”与“定义”是怎么理解的,
我的理解如下:
“声明”变量,只是仅仅声明,而“定义”变量,指声明了,并且赋值了。
例如:

复制代码 代码如下:

var name;//只是声明
var num = 11;//声明,并且赋值,即定义了
var password = "yangjiang";//声明,并且赋值,即定义了

下面是几点总结:
变量的作用域:全局的和局部的。(注意:如果尝试读取一个未声明的变量的值,javascript会生成一个错误)
第一点:在都使用var关键字修饰变量的情况下,如果给一个局部变量或函数的参数声明的名字与某个全局变量的名字相同,
那么就有效地隐藏了这个全局变量。
例如:
复制代码 代码如下:

var scope1 = "global";//var修饰
function checksScope(){
var scope1 = "local";//var修饰
document.write(scope1);
}checksScope();//local

第二点:如果尝试给一个未用 var 关键字声明的变量,那么,隐式声明的变量总是被创建为全局变量,即使
该变量只在一个函数体内使用(只有该函数运行了,才会发生作用),注意不支持函数嵌套的情形。
例如:
复制代码 代码如下:

scope2 = "globalAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
function checkScopeA(){
scope2 = "localAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
document.write("
"+scope2);
myscope = "myLocalAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
document.write(","+myscope);
}
checkScopeA();//localAAAAA,myLocalAAAAA *A
document.write("
"+scope2);//localAAAAA *B
document.write("
"+myscope);//myLocalAAAAA *C

如果将上面的例子中的 *A处的代码注释掉,
例如:
复制代码 代码如下:

scope2 = "globalAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
function checkScopeA(){
scope2 = "localAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
document.write("
"+scope2);
myscope = "myLocalAAAAA";//没有使用var修饰(js会默认将其声明为全局变量)
document.write(","+myscope);
}
//checkScopeA(); *A
document.write("
"+scope2);//globalAAAAA *B
document.write("
"+myscope);//发生错误 *C

因为函数checkScopeA没有执行,所以 *B处输出为globalAAAAA;
因为函数checkScopeA没有执行,所以变量myscope没有声明,如果尝试读取一个未声明的变量,会发生错误。
第三点:
在javascript中,函数的定义是可以嵌套的。由于 每个函数都有它自己的局部作用域,所以有可能出现几个局部作用域的嵌套层。
例如:
复制代码 代码如下:

var scope3 = "global scope"; //定义了一个全局变量
function checkScopeB(){
var scope3 = "local scope"; //定义了一个局部变量,覆盖了全局变量scope3
function nested(){
var scope3 = "nested scope"; //在函数的函数的内部,定义了一个局部变量
document.write("
"+scope3); //nested scope
}
nested();
}
checkScopeB();//nested scope

第四点:
在javascript中,没有块级作用域,函数中声明的所有变量,无论是在哪里声明的,在整个函数中它们都是有声明的。
在javascript中,没有块级作用域,函数中定义的所有变量,无论是在哪里定义的,在整个函数中它们都是有定义的。
例如:
复制代码 代码如下:

function test(o){//根据以上的说明:此函数中的i,j,k三个变量的作用域是相同的。
var i = 0; //变量 i 在整个函数中都有定义
if(typeof o == "object"){
var j = 0 ; //变量 j 在整个函数中都有定义,而不仅仅是在 if 语句块
for(var k=0;kdocument.write("
k的值为:"+k);
}
document.write("
for循环外k的值:"+k);//此时的 k 仍然被定义了,k=10
}
document.write("
j的值:"+j); //变量 j 被声明了,但可能没有被初始化 因为可能往函数中 传入的参数 不是对象 ,if语句块不会执行
}

下面通过两种方式调用此函数:
方式一:传入对象
test({});//输出结果:上例中的注释
方式二:什么都不传
test();//输出结果:j的值:undefined
想不明白的是,在第二种方式中的输出结果,为什么会是 undefined。我当时猜的是:j的值:0
后来,这本书上面说:
由于局部变量在整个函数体内都是有声明(或定义)的,这就意味着在整个函数体中都隐藏了同名的全局
变量。虽然 局部变量在整个函数体内中都是有声明(或定义)的,但是在执行var语句之前,它是不会被初始化的。
这样的话,上面的方式二调用的输出结果,就比较好解释了,由于变量j在整个函数中都有定义,而又由于传入函数的参数为空,所以函数体中的if语句不会执行,从而使得j的值为undefined.(这是我参照上面书上说的那句话的理解)
下面的例子,更好的说明:
复制代码 代码如下:

var sssss = "全局变量";
function f(){
document.write("
"+sssss);//输出:undefined 而不是输出"全局变量"
var sssss = "局部变量";
document.write("
"+sssss);//输出:局部变量
}
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

PHP 函數的變數作用域是如何決定的? PHP 函數的變數作用域是如何決定的? Apr 16, 2024 pm 04:51 PM

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

深入理解 Golang 函數生命週期與變數作用域 深入理解 Golang 函數生命週期與變數作用域 Apr 19, 2024 am 11:42 AM

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

Go語言中的變數作用域與生命週期 Go語言中的變數作用域與生命週期 Jun 01, 2023 pm 12:31 PM

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

Golang函數如何定義變數作用域? Golang函數如何定義變數作用域? Apr 11, 2024 pm 12:27 PM

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

PHP 5.6變數作用域:如何使用static關鍵字定義靜態變數 PHP 5.6變數作用域:如何使用static關鍵字定義靜態變數 Jul 30, 2023 pm 11:02 PM

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

如何在PHP中使用變數 如何在PHP中使用變數 May 20, 2023 pm 02:33 PM

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

使用Python的locals()函數取得目前作用域的變數 使用Python的locals()函數取得目前作用域的變數 Aug 21, 2023 pm 09:52 PM

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

Golang函數的變數作用域是什麼 Golang函數的變數作用域是什麼 Dec 22, 2023 pm 02:39 PM

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

See all articles