JavaScript裝箱及拆箱boxing及unBoxing用法解析
首先我們來(lái)看看這段代碼
var s1 = 'abc';var s2 = s1.indexOf('a')
s1 是個(gè) string 啊,怎么會(huì)有 indexOf() 方法呢?
這里就涉及到了 JavaScript 中的裝箱與拆箱的概念了
裝箱:把基本數(shù)據(jù)類型轉(zhuǎn)化為對(duì)應(yīng)的引用數(shù)據(jù)類型的操作
在《javascript高級(jí)程序設(shè)計(jì)》中有這樣一句話:
每當(dāng)讀取一個(gè)基本類型的時(shí)候,后臺(tái)就會(huì)創(chuàng)建一個(gè)對(duì)應(yīng)的基本包裝類型對(duì)象,從而讓我們能夠調(diào)用一些方法來(lái)操作這些數(shù)據(jù)。
還是拿最開(kāi)始的例子
var s1 = 'abc';var s2 = s1.indexOf('a')
變量s1是一個(gè)基本類型值,它不是對(duì)象,它不應(yīng)該有方法。但是js內(nèi)部為我們完成了一系列處理(即裝箱),使得它能夠調(diào)用方法,實(shí)現(xiàn)的機(jī)制如下:
(1)創(chuàng)建String類型的一個(gè)實(shí)例;
(2)在實(shí)例上調(diào)用指定的方法;
(3)銷毀這個(gè)實(shí)例;
下面來(lái)看看代碼實(shí)現(xiàn):
var s1 = new String('some text');var s2 = s1.substring(2);s1 = null;
這樣就完成裝箱,我們也就能在s1上調(diào)用方法了
拆箱:將引用類型對(duì)象轉(zhuǎn)換為對(duì)應(yīng)的值類型對(duì)象
拆箱:將引用類型對(duì)象轉(zhuǎn)換為對(duì)應(yīng)的值類型對(duì)象
它是通過(guò)引用類型的valueOf()或者toString()方法來(lái)實(shí)現(xiàn)的。如果是自定義的對(duì)象,你也可以自定義它的valueOf()/tostring()方法,實(shí)現(xiàn)對(duì)這個(gè)對(duì)象的拆箱。
var objNum = new Number(123); var objStr =new String('123'); console.log( typeof objNum ); //object console.log( typeof objStr ); //object console.log( typeof objNum.valueOf() ); //number console.log( typeof objStr.valueOf() ); //string console.log( typeof objNum.toString() ); // string console.log( typeof objStr.toString() ); // string
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁(yè)2. 利用CSS3新特性創(chuàng)建透明邊框三角3. ASP.NET MVC使用jQuery ui的progressbar實(shí)現(xiàn)進(jìn)度條4. 如何在Notepad++中配置python執(zhí)行命令5. Python 輸出詳細(xì)的異常信息(traceback)方式6. 原生js生成圖片驗(yàn)證碼7. IDEA創(chuàng)建Java項(xiàng)目導(dǎo)出Jar包運(yùn)行8. Vue 自適應(yīng)高度表格的實(shí)現(xiàn)方法9. Vue中nvm-windows的安裝與使用教程(親測(cè))10. .NET使用StackTrace獲取方法調(diào)用信息的代碼演示
