JavaScript高級(jí)程序設(shè)計(jì)之變量與作用域
1、原始值與引用值
6種簡單數(shù)據(jù)類型的值都是原始值, 原始值通過變量賦值給另一個(gè)變量時(shí),會(huì)復(fù)制一個(gè)出一個(gè)新的值,兩者相互獨(dú)立。
let num1 = 5 let num2 = num1
引用值通過變量賦值給另一個(gè)變量時(shí),也會(huì)復(fù)制一個(gè)值,這個(gè)值其實(shí)是一個(gè)指針(引用),該指針指向的還是同一個(gè)對象。
let obj1 = new Object() let obj2 = obj1
既然是指向同一個(gè)引用對象,那么給obj1
添加屬性,也會(huì)作用到obj2
身上去。
obj1.name = "zhangsan" console.log(obj2.name) // zhangsan
函數(shù)在傳參的過程中,只有一種情況就是按照值傳遞,這跟變量的賦值是一個(gè)樣。只不過,對于引用值,傳遞的值是指針,但指針指向的還是同一個(gè)對象。
2、instanceof
typeof
一般適合用來判斷原始值,對于引用值并不使用,因?yàn)?null
和 其它對象返回的都是 object,具體是什么類型的對象并不知道。 而判斷引用值具體是什么類型對象最好的方法就是用 instanceof
表達(dá)式。
console.log(1 instanceof Object) //false let obj = new Object(); console.log(obj instanceof Object) //true console.log(null instanceof Object) //false function fun(){ // } console.log(fun instanceof Object) //true console.log(fun instanceof Function) //true console.log([] instanceof Object) //true console.log([] instanceof Array) //true
3、作用域
變量的作用范圍稱為作用域或者執(zhí)行上下文,變量脫離了該作用域不再可見,所有系統(tǒng)查找一個(gè)變量時(shí)是有一個(gè)作用域鏈的。先從引用該變量最近的塊作用域找,沒找到繼續(xù)往外局部作用域找,再?zèng)]找到就在全局作用域中查找。如果還沒找到就會(huì)報(bào)錯(cuò) ReferenceError: xxx is not defined
。
到此這篇關(guān)于JavaScript高級(jí)程序設(shè)計(jì)之變量與作用域的文章就介紹到這了,更多相關(guān)JavaScript變量與作用域內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中Reduce10個(gè)常用場景技巧
這篇文章主要為大家介紹了JavaScript中Reduce10個(gè)常用場景和技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06微信小程序 數(shù)據(jù)交互與渲染實(shí)例詳解
這篇文章主要介紹了微信小程序 數(shù)據(jù)交互與渲染實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01