欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript數(shù)據(jù)類(lèi)型轉(zhuǎn)換詳解(推薦)

 更新時(shí)間:2021年05月14日 10:57:14   作者:努力學(xué)習(xí)前端  
眾所周知JavaScript是一門(mén)弱類(lèi)型(語(yǔ)言,即變量的類(lèi)型是不確定的。所以下面這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)據(jù)類(lèi)型轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下

JS數(shù)據(jù)類(lèi)型

在 JavaScript 語(yǔ)言中數(shù)據(jù)類(lèi)型分為2大類(lèi):基本數(shù)據(jù)類(lèi)型和復(fù)雜數(shù)據(jù)類(lèi)型

基本數(shù)據(jù)類(lèi)型有:

  • number
  • string
  • boolean
  • null
  • undefined
  • symbol
  • bigint

復(fù)雜數(shù)據(jù)類(lèi)型有:

  • 標(biāo)準(zhǔn)普通對(duì)象:object
  • 標(biāo)準(zhǔn)特殊對(duì)象:Array、RegExp、Date、Math、Error……
  • 非標(biāo)準(zhǔn)特殊對(duì)象:Number、String、Boolean……
  • 可調(diào)用/執(zhí)行對(duì)象「函數(shù)」:function

類(lèi)型之間的轉(zhuǎn)換

類(lèi)型轉(zhuǎn)換可以分為兩種:隱式類(lèi)型轉(zhuǎn)換 和 顯式類(lèi)型轉(zhuǎn)換。

顯式類(lèi)型強(qiáng)制轉(zhuǎn)換 是指當(dāng)開(kāi)發(fā)人員通過(guò)編寫(xiě)適當(dāng)?shù)拇a用于在類(lèi)型之間進(jìn)行轉(zhuǎn)換,比如:Number(value)。

隱式類(lèi)型轉(zhuǎn)換 是指在對(duì)不同類(lèi)型的值使用運(yùn)算符時(shí),值可以在類(lèi)型之間自動(dòng)的轉(zhuǎn)換,比如0 == null

在 JS 中只有 3 種類(lèi)型的轉(zhuǎn)換:

  • 轉(zhuǎn)化為 Number 類(lèi)型:Number() / parseFloat() / parseInt()
  • 轉(zhuǎn)化為 String 類(lèi)型:String() / toString()
  • 轉(zhuǎn)化為 Boolean 類(lèi)型: Boolean()

類(lèi)型轉(zhuǎn)換的邏輯無(wú)論在原始類(lèi)型和對(duì)象類(lèi)型上,他們都只會(huì)轉(zhuǎn)換成上面 3 種類(lèi)型之一。所以只需要弄清在什么場(chǎng)景下應(yīng)該轉(zhuǎn)成哪種類(lèi)型就可以了

轉(zhuǎn)換為boolean

顯式:Boolean()方法可以用來(lái)顯式將值轉(zhuǎn)換成布爾型。

隱式:隱式類(lèi)型轉(zhuǎn)換通常在邏輯判斷或者有邏輯運(yùn)算符時(shí)被觸發(fā)(|| && !)。

boolean 類(lèi)型轉(zhuǎn)換只會(huì)有 true 或者 false 兩種結(jié)果。除了“0/NaN/空字符串/null/undefined”五個(gè)值是false,其余都是true

轉(zhuǎn)換為string

顯式:String()方法可以用來(lái)顯式將值轉(zhuǎn)為字符串。

String([1,2,3])    //"1,2,3"
String({})    //"[object Object]"

隱式轉(zhuǎn)換通常在有 + 運(yùn)算符并且有一個(gè)操作數(shù)是 string 類(lèi)型時(shí)被觸發(fā)。

“+”代表的字符串拼接,如果下面的情況存在時(shí)會(huì)觸發(fā)轉(zhuǎn)換

  • 有兩邊,一邊是字符串,則會(huì)變成字符串拼接;
  • 有兩邊,一邊是對(duì)象
1 + {}     //"1[object Object]"
NaN + {} //"NaN[object Object]"

轉(zhuǎn)換為number

顯式:Number()方法可以用來(lái)顯式將值轉(zhuǎn)換成數(shù)字類(lèi)型。

字符串轉(zhuǎn)換為數(shù)字:空字符串變?yōu)?,如果出現(xiàn)任何一個(gè)非有效數(shù)字字符,結(jié)果都是NaN

Number("")           //0
Number("10px")       //NaN
Number("10")         //10

布爾轉(zhuǎn)換為數(shù)字

Number(true)         //1
Number(false)        //0

null和undefined轉(zhuǎn)換成數(shù)字

Number(null)         //0
Number(undefined)    //NaN

Symbol無(wú)法轉(zhuǎn)換為數(shù)字,會(huì)報(bào)錯(cuò):Uncaught TypeError: Cannot convert a Symbol value to a number

BigInt去除“n”

Number(12312412321312312n)     //12312412321312312

對(duì)象轉(zhuǎn)換為數(shù)字,會(huì)按照下面的步驟去執(zhí)行

先調(diào)用對(duì)象的 Symbol.toPrimitive 這個(gè)方法,如果不存在這個(gè)方法

再調(diào)用對(duì)象的 valueOf 獲取原始值,如果獲取的值不是原始值

再調(diào)用對(duì)象的 toString 把其變?yōu)樽址?/p>

最后再把字符串基于Number()方法轉(zhuǎn)換為數(shù)字

let obj ={
    name:'xxx'
}
console.log(obj-10) // 數(shù)學(xué)運(yùn)算:先把obj隱式轉(zhuǎn)換為數(shù)字,再進(jìn)行運(yùn)算
//運(yùn)行機(jī)制
obj[Symbol.toPrimitive] //undifined 
obj.valueof() // {name:xxx}
obj.toString() // [object object]
Number ("[object object]") // NaN
NaN-10 // NaN 
obj+10 //"[object object]10"

隱式:number 的隱式類(lèi)型轉(zhuǎn)換是比較復(fù)雜的,因?yàn)樗梢栽谙旅娑喾N情況下被觸發(fā)。

  • 比較操作(>, <, <=, >=)
  • 按位操作(| & ^ ~)
  • 算數(shù)操作(- + * / %), 注意:當(dāng) + 操作存在任意的操作數(shù)是 string 類(lèi)型時(shí),不會(huì)觸發(fā) number 類(lèi)型的隱式轉(zhuǎn)換
  • 一元 + 操作

操作符==兩邊的隱式轉(zhuǎn)換規(guī)則

如果兩邊數(shù)據(jù)類(lèi)型不同,需要先轉(zhuǎn)為相同類(lèi)型,然后再進(jìn)行比較,以下幾種情況需要注意一下:

可以根據(jù)這個(gè)圖進(jìn)行參考,如對(duì)象和布爾比較的話(huà),

  • 對(duì)象 => 字符串 => 數(shù)值
  • 布爾值 => 數(shù)值。

對(duì)象==字符串

[1,2,3]=='1,2,3'              //true
[1,2,3][Symbol.toPrimitive]   //undefined
[1,2,3].valueOf()             //[1, 2, 3]
[1,2,3].toString()            //"1,2,3"

null/undefined

null==undefined      //true 
null===undefined     //false  不會(huì)發(fā)生隱試類(lèi)型轉(zhuǎn)換

注意:null/undefined和其他任何值都不相等

對(duì)象==對(duì)象

比較的是堆內(nèi)存地址,地址相同則相等

{}=={}      //false   因?yàn)楸容^的是地址

NaN

除了以上情況,只要兩邊類(lèi)型不一致,剩下的都是轉(zhuǎn)換為數(shù)字,然后再進(jìn)行比較

需要注意的情況

{} + [] === 0               // true
[] + {} === 0               // false

[] + {}  = "[object Object]"
{} + []  = 0
/**
  * 對(duì)于編譯器而言,代碼塊不會(huì)返回任何的值
  * 接著+[]就變成了一個(gè)強(qiáng)制轉(zhuǎn)number的過(guò)程
  * []通過(guò)ToPrimitive變成'',最后''通過(guò)ToNumber操作轉(zhuǎn)換成0
  **/

結(jié)尾練習(xí)

let result = 100 + true + 21.2 + null + undefined + “Tencent” + [] + null + 9 + false;

result的結(jié)果是?

1.首先100 + true
+連接符兩邊存在Number類(lèi)型,true轉(zhuǎn)number為1,進(jìn)行加法運(yùn)算,結(jié)果為:101
2.101 + 21.2
+連接符兩邊均為Number類(lèi)型,進(jìn)行加法運(yùn)算,結(jié)果為:122.2
3.122.2 + null
+連接符兩邊存在Number類(lèi)型,null轉(zhuǎn)number為0,進(jìn)行加法運(yùn)算,結(jié)果為:122.2
4.122.2 + undefined
+連接符兩邊存在Number類(lèi)型,undefined轉(zhuǎn)number為NaN,NaN與任何數(shù)據(jù)類(lèi)型計(jì)算都為NaN,結(jié)果為:NaN
5.NaN + "Tencent"
+連接符兩邊存在String類(lèi)型,NaN轉(zhuǎn)string為"NaN",進(jìn)行字符串拼接,結(jié)果為:"NaNTencent"
6."NaNTencent" + []
+連接符兩邊存在String類(lèi)型,[]轉(zhuǎn)string為"",進(jìn)行字符串拼接,結(jié)果為:"NaNTencent"
7."NaNTencent" + null
+連接符兩邊存在String類(lèi)型,null轉(zhuǎn)string為"null",進(jìn)行字符串拼接,結(jié)果為:"NaNTencentnull"
8."NaNTencentnull" + 9
+連接符存在String類(lèi)型,9轉(zhuǎn)string為"9",進(jìn)行字符串拼接,結(jié)果為:"NaNTencentnull9"
9."NaNTencentnull9" + false
+連接符存在String類(lèi)型,false轉(zhuǎn)string為"false",進(jìn)行字符串拼接,結(jié)果為:"NaNTencentnull9false"

總結(jié)

到此這篇關(guān)于JavaScript數(shù)據(jù)類(lèi)型轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)js數(shù)據(jù)類(lèi)型轉(zhuǎn)換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js輪播圖之旋轉(zhuǎn)木馬效果

    js輪播圖之旋轉(zhuǎn)木馬效果

    這篇文章主要為大家詳細(xì)介紹了js輪播圖之旋轉(zhuǎn)木馬效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶(hù)名存儲(chǔ)案例

    JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶(hù)名存儲(chǔ)案例

    本文主要介紹了JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶(hù)名存儲(chǔ)案例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Javascript中常用的檢測(cè)方法小結(jié)

    Javascript中常用的檢測(cè)方法小結(jié)

    這篇文章主要給大家總結(jié)了Javascript中常用的檢測(cè)方法,通過(guò)這些總結(jié)的方法相信對(duì)大家學(xué)習(xí)或者使用Javascript能有所幫助,有需要的朋友們下面來(lái)一起看看吧。
    2016-10-10
  • JavaScript解析URL參數(shù)示例代碼

    JavaScript解析URL參數(shù)示例代碼

    通過(guò)js解析URL參數(shù),本文創(chuàng)建了一個(gè)js類(lèi),并引用Request.QueryString,感興趣的朋友可以參考下,希望對(duì)大家有所幫助
    2013-08-08
  • JavaScript中的類(lèi)繼承

    JavaScript中的類(lèi)繼承

    JavaScript一種沒(méi)有類(lèi)的,面向?qū)ο蟮恼Z(yǔ)言,它使用原型繼承來(lái)代替類(lèi)繼承。
    2010-11-11
  • js實(shí)現(xiàn)網(wǎng)頁(yè)隨機(jī)切換背景圖片的方法

    js實(shí)現(xiàn)網(wǎng)頁(yè)隨機(jī)切換背景圖片的方法

    這篇文章主要介紹了js實(shí)現(xiàn)網(wǎng)頁(yè)隨機(jī)切換背景圖片的方法,涉及數(shù)組、隨機(jī)函數(shù)與css樣式的調(diào)用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-11-11
  • JavaScript enum枚舉類(lèi)型定義及使用方法

    JavaScript enum枚舉類(lèi)型定義及使用方法

    這篇文章主要介紹了JavaScript enum枚舉類(lèi)型定義及使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • 微信小程序?qū)崿F(xiàn)輪播圖標(biāo)題跑馬燈

    微信小程序?qū)崿F(xiàn)輪播圖標(biāo)題跑馬燈

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)輪播圖標(biāo)題跑馬燈,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JavaScript將一個(gè)數(shù)組插入到另一個(gè)數(shù)組的方法

    JavaScript將一個(gè)數(shù)組插入到另一個(gè)數(shù)組的方法

    這篇文章主要介紹了JavaScript將一個(gè)數(shù)組插入到另一個(gè)數(shù)組的方法,涉及javascript中Array.prototype.push.apply方法的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03
  • js 為label標(biāo)簽和div標(biāo)簽賦值的方法

    js 為label標(biāo)簽和div標(biāo)簽賦值的方法

    這篇文章介紹了js 為label標(biāo)簽和div標(biāo)簽賦值的方法,有需要的朋友可以參考一下
    2013-08-08

最新評(píng)論