JavaScript裝箱及拆箱boxing及unBoxing用法解析
首先我們來看看這段代碼
var s1 = "abc";
var s2 = s1.indexOf("a")
s1 是個 string 啊,怎么會有 indexOf() 方法呢?
這里就涉及到了 JavaScript 中的裝箱與拆箱的概念了
裝箱:把基本數(shù)據(jù)類型轉(zhuǎn)化為對應的引用數(shù)據(jù)類型的操作
在《javascript高級程序設計》中有這樣一句話:
每當讀取一個基本類型的時候,后臺就會創(chuàng)建一個對應的基本包裝類型對象,從而讓我們能夠調(diào)用一些方法來操作這些數(shù)據(jù)。
還是拿最開始的例子
var s1 = "abc";
var s2 = s1.indexOf("a")
變量s1是一個基本類型值,它不是對象,它不應該有方法。但是js內(nèi)部為我們完成了一系列處理(即裝箱),使得它能夠調(diào)用方法,實現(xiàn)的機制如下:
(1)創(chuàng)建String類型的一個實例;
(2)在實例上調(diào)用指定的方法;
(3)銷毀這個實例;
下面來看看代碼實現(xiàn):
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
這樣就完成裝箱,我們也就能在s1上調(diào)用方法了
拆箱:將引用類型對象轉(zhuǎn)換為對應的值類型對象
拆箱:將引用類型對象轉(zhuǎn)換為對應的值類型對象
它是通過引用類型的valueOf()或者toString()方法來實現(xiàn)的。如果是自定義的對象,你也可以自定義它的valueOf()/tostring()方法,實現(xiàn)對這個對象的拆箱。
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
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
el-popover放在el-table中點擊無反應問題解決方案
我們想在table中給btn加彈框但是?el-popover點擊按鈕沒有任何反應,解決思路是通過給每個el-popover都加上單獨的id,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2024-04-04基于JS實現(xiàn)網(wǎng)頁中的選項卡(兩種方法)
這篇文章主要介紹了用js語句實現(xiàn)網(wǎng)頁中的選項卡(兩種方法),非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-06-06刪除數(shù)組條目中重復的條目(可能有多個),返回值是一個僅包含被刪除的重復條目的新數(shù)組。
刪除數(shù)組條目中重復的條目(可能有多個),返回值是一個僅包含被刪除的重復條目的新數(shù)組。...2007-09-09