什么叫引用類(lèi)型?
是一個(gè)抽象的集合概念,是一個(gè)把數(shù)據(jù)和功能組織在一起的結(jié)構(gòu)
它也被稱(chēng)為對(duì)象定義
他們描述了自己的對(duì)象應(yīng)有的屬性和方法
對(duì)象被認(rèn)為是某個(gè)特定引用類(lèi)型的實(shí)例
例如:
let obj = new Date()
obj就是Date引用類(lèi)型的一個(gè)實(shí)例
js有很多自帶的基本引用類(lèi)型如Date秋秤、RegExp(相對(duì)于Perl有局限)
原始值包裝類(lèi)型:Boolen屉更、Number余指、String
原始值包裝類(lèi)型洋侨,說(shuō)俗點(diǎn)就是把原始值包裝成引用值,它就是一類(lèi)特殊的引用類(lèi)型而已
實(shí)例化原始值包裝類(lèi)型很簡(jiǎn)單 let numObj = new Number(233)
(其實(shí)就是顯示地去構(gòu)造非對(duì)象的變量)
我們看到前面這個(gè)例子:
let name1 = "lpj";
let name2 = new String("lpj")'
name1.age = 19;
name2.age = 19;
console.log(name1.age);//undefined name1類(lèi)型為string
console.log(name2.age);//19 name2類(lèi)型為object
顯然坦敌,試圖給string類(lèi)型變量加上屬性不符合語(yǔ)法侣诵,但是痢法,如果是這樣:
let s1 = "some text"
let s2 = s1.substring(2)//成功賦值
實(shí)際上,這包含了以下過(guò)程:(將非對(duì)象臨時(shí)對(duì)象化)
let s1 = new String("some text");//臨時(shí)切換成對(duì)象
let s2 = s1.substring(2);//調(diào)用原型鏈方法
s1 = null;//銷(xiāo)毀實(shí)例
//另外杜顺,如果你一開(kāi)始就構(gòu)造的話(huà)财搁,是沒(méi)這么多事的
let str = new String("something");
str.sb = 'kkp';
console.log(str.sb)//kkp
js紅寶書(shū)說(shuō):這是因?yàn)椤昂笈_(tái)進(jìn)行了很多處理”,我認(rèn)為躬络,應(yīng)該指的就是把非對(duì)象類(lèi)型轉(zhuǎn)化為對(duì)象后進(jìn)行原型鏈的搜索
- 對(duì)比詳情
引用類(lèi)型(Date之類(lèi))和原始值包裝類(lèi)型主要區(qū)別在于生命周期:
通過(guò)new實(shí)例化引用類(lèi)型后(也就是上述過(guò)程)該實(shí)例會(huì)被銷(xiāo)毀尖奔,因此,這解釋了為什么name1.age = 19;console.log(name1.age);
是undefined穷当,事實(shí)上提茁,第一句會(huì)執(zhí)行上述對(duì)象化過(guò)程,但被銷(xiāo)毀了馁菜。事實(shí)上后一句執(zhí)行過(guò)程中也創(chuàng)建了String對(duì)象(就像let s2 = s1.substring(2);
這一句一樣茴扁,但發(fā)現(xiàn)沒(méi)有這個(gè)屬性,所以返回undefined汪疮,同樣峭火,也會(huì)銷(xiāo)毀這個(gè)實(shí)例 - 那么 直接new不就行了嗎
是的,但應(yīng)在確實(shí)有必要時(shí)才如此操作智嚷,否則會(huì)使開(kāi)發(fā)者疑惑:這到底是引用值還是原始值 - 此外:
new String('hhh')
和new Object('hhh')
是完全等價(jià)的
因?yàn)镺bject構(gòu)造函數(shù)本身是一個(gè)工廠(chǎng)模式函數(shù)卖丸,能夠根據(jù)輸入返回對(duì)應(yīng)原始值包裝類(lèi)型的實(shí)例,Number和Boolen同理
總之纤勒,這種對(duì)象化的行為可以在保持變量為原始值的同時(shí)坯苹,讓原始值擁有對(duì)象可繼承的特性
小結(jié):通過(guò)內(nèi)置的引用類(lèi)型隆檀,可以創(chuàng)建特定類(lèi)型的對(duì)象摇天,這些對(duì)象往往在原型鏈上有著許多專(zhuān)門(mén)編寫(xiě)的屬性和方法,比如原始值String變量就是通過(guò)原始值包裝類(lèi)型來(lái)臨時(shí)創(chuàng)建對(duì)象以訪(fǎng)問(wèn)特殊方法恐仑。
單例內(nèi)置對(duì)象以及相關(guān)概念
對(duì)象類(lèi)型
先理解下什么是宿主環(huán)境:由web瀏覽器或是桌面應(yīng)用系統(tǒng)造就的js引擎執(zhí)行的環(huán)境即宿主環(huán)境
1泉坐、本地對(duì)象
ECMA-262 把本地對(duì)象(native object)定義為“獨(dú)立于宿主環(huán)境的 ECMAScript 實(shí)現(xiàn)提供的對(duì)象”。
??本地對(duì)象包含但不限于Object裳仆、Function腕让、Array、String歧斟、Boolean纯丸、Number、Date静袖、RegExp觉鼻、各種錯(cuò)誤類(lèi)對(duì)象(Error、EvalError队橙、RangeError坠陈、ReferenceError、SyntaxError、TypeError拙吉、URIError)
注意:這里的Object拍棕、Function、Array等不是指構(gòu)造函數(shù)贮匕,而是指對(duì)象的類(lèi)型
2姐仅、內(nèi)置對(duì)象
ECMA-262 把內(nèi)置對(duì)象(built-in object)定義為“由 ECMAScript 實(shí)現(xiàn)提供的、獨(dú)立于宿主環(huán)境的所有對(duì)象刻盐,在 ECMAScript 程序開(kāi)始執(zhí)行時(shí)出現(xiàn)”萍嬉。這意味著開(kāi)發(fā)者不必明確實(shí)例化內(nèi)置對(duì)象,它已被實(shí)例化了隙疚。ECMA-262 只定義了兩個(gè)內(nèi)置對(duì)象壤追,即 Global 和 Math (它們也是本地對(duì)象,根據(jù)定義供屉,每個(gè)內(nèi)置對(duì)象都是本地對(duì)象)行冰。
當(dāng)代碼執(zhí)行時(shí),全局作用域就會(huì)存在這兩個(gè)對(duì)象了
- Global
全局作用域定義的函數(shù)和變量都會(huì)變成Global的屬性
例如:isNAN()函數(shù)伶丐,顯然它不定義于原型鏈上悼做,而是在Global上
除了通過(guò)window對(duì)象來(lái)訪(fǎng)問(wèn),還可以通過(guò)let global = function(){return this;}()
(后加()是立即執(zhí)行函數(shù))
Global其實(shí)并不存在(有點(diǎn)哲學(xué))對(duì)于web瀏覽器而言哗魂,Global有一個(gè)代言人window肛走,但是window并不是ECMAScripta規(guī)定的內(nèi)置對(duì)象,因?yàn)閣indow對(duì)象是相對(duì)于web瀏覽器而言的录别,而js不僅僅可以用在瀏覽器中朽色。
- Math
專(zhuān)門(mén)放數(shù)學(xué)公式和操作