2020-3-19 seo達(dá)人
JS中數(shù)據(jù)類(lèi)型轉(zhuǎn)換
目前為止,我了解到的JavaScript中共有6種類(lèi)型。通過(guò)typeof關(guān)鍵字可以查看類(lèi)型名稱(chēng)。
數(shù)據(jù)的類(lèi)型:
字符串:若值為字符串,則顯示為String。字符串使用單引號(hào)或雙引號(hào)括起來(lái)。在控制臺(tái)顯示為黑色。
數(shù)字:若值為數(shù)字,則顯示為Number。在控制臺(tái)顯示為藍(lán)色。
布爾值:若值為布爾值,則顯示為Boolean。它的值只有”true”和”false”。
對(duì)象:若值為對(duì)象,則顯示為Object。
未定義:若值未定義,也就是僅僅聲明,但未進(jìn)行賦值,則顯示為Undefined。
空值:若值為指向不引用對(duì)象的指針,則顯示為Null,它與Undefined不同,以后慢慢深入了解。
以下表格詳細(xì)寫(xiě)出了各種情況下相互轉(zhuǎn)換的結(jié)果,可作為輔助記憶。
值 轉(zhuǎn)換為字符串 轉(zhuǎn)換為數(shù)字 轉(zhuǎn)換為布爾值 轉(zhuǎn)換為對(duì)象
undefined “undefined” NaN false throw TypeError
null “null” 0 false throw TypeError
true “true” 1 new Boolean(“true”)
false “false” 0 new Boolean(“false”)
“” 0 false new String("")
“1.2” 1.2 true new String(“1.2”)
“1.2a” NaN true new String(“1.2a”)
“aaa” NaN true new String(“aaa”)
0 “0” false new Number(0)
1 “1” true new Number(1)
NaN “NaN” false new Number(NaN)
Infinity “Infinity” true new Number(Infinity)
[] “” 0 true
[9] “9” 9 true
[“a”“b”] “a,b” NaN true
在Js中,數(shù)據(jù)類(lèi)型可以相互轉(zhuǎn)換,轉(zhuǎn)換的方式有兩種,隱式轉(zhuǎn)換和強(qiáng)制轉(zhuǎn)換,首先來(lái)說(shuō)一些隱式轉(zhuǎn)換。在進(jìn)行代碼書(shū)寫(xiě)時(shí),要經(jīng)常提醒自己所使用的元素是什么數(shù)據(jù)類(lèi)型,在進(jìn)行某些操作后是否會(huì)導(dǎo)致數(shù)據(jù)類(lèi)型的變化,原因就是Js會(huì)對(duì)數(shù)據(jù)進(jìn)行類(lèi)型的隱式轉(zhuǎn)換。
隱式轉(zhuǎn)換舉例:
(+)加法運(yùn)算的隱式轉(zhuǎn)換:加號(hào)兩邊只要出先了字符串,就自動(dòng)將兩者均轉(zhuǎn)化為字符串,使兩個(gè)字符串發(fā)生“拼接”,最后生成的結(jié)果也是一個(gè)字符串;如果前后都不是字符串,則轉(zhuǎn)化為數(shù)字類(lèi)型進(jìn)行計(jì)算。
(-、*、/、%)其他算數(shù)運(yùn)算的隱式轉(zhuǎn)換:前后都轉(zhuǎn)化為數(shù)字類(lèi)型進(jìn)行計(jì)算。
(?。┻壿嫹堑碾[式轉(zhuǎn)換:他會(huì)將他后面的變量或表達(dá)式轉(zhuǎn)換為布爾值。
(<,>)比較運(yùn)算符的轉(zhuǎn)換:如果前后存在一個(gè)數(shù)字,會(huì)對(duì)另一個(gè)轉(zhuǎn)化為數(shù)字進(jìn)行比較;如果前后均為字符串,會(huì)依次比較對(duì)應(yīng)字符的編碼大小,老大比老大,老二比老二,依次進(jìn)行。
(&&,||)邏輯運(yùn)算符的轉(zhuǎn)換:先將前后都轉(zhuǎn)化為布爾值再進(jìn)行判斷,要記住的是,只有undefined,null,0,””,NaN會(huì)轉(zhuǎn)化成為false,其他都是true。
(== 、===)這里作為補(bǔ)充說(shuō)明,null與Undefined相等但不全等,NaN與任何都不相等。
強(qiáng)制轉(zhuǎn)換的方式:
1.轉(zhuǎn)化為字符串
String(里面寫(xiě)待轉(zhuǎn)化的內(nèi)容):沒(méi)什么好解釋的,就是強(qiáng)制將你所看到的轉(zhuǎn)化為你所看到的。
toString(里面寫(xiě)目標(biāo)數(shù)字是幾進(jìn)制),寫(xiě)法為:待轉(zhuǎn)化內(nèi)容.toString(目標(biāo)內(nèi)容是幾進(jìn)制)。括號(hào)內(nèi)不寫(xiě)時(shí)默認(rèn)為10。
toFixed(保留小數(shù)的位數(shù)),寫(xiě)法為待轉(zhuǎn)化內(nèi)容.toFixed(保留小數(shù)的位數(shù)),存在精度誤差。
2.轉(zhuǎn)化為數(shù)字
Number(),只有所轉(zhuǎn)化內(nèi)容在肉眼看到的全是數(shù)字,才會(huì)正常轉(zhuǎn)化;false會(huì)轉(zhuǎn)化為0,true會(huì)轉(zhuǎn)化為1;null會(huì)轉(zhuǎn)化為0;undefined會(huì)轉(zhuǎn)化為NaN;其他情況均為NaN。
parseInt(待轉(zhuǎn)化內(nèi)容,待轉(zhuǎn)化內(nèi)容的進(jìn)制方式),與toString互為逆運(yùn)算,不寫(xiě)的話(huà)默認(rèn)為10。如果待轉(zhuǎn)化內(nèi)容為字符串,若以數(shù)字開(kāi)頭,可以從開(kāi)始轉(zhuǎn)換到字符前為止變成數(shù)值。布爾值,undefined,null經(jīng)過(guò)轉(zhuǎn)化均為NaN。
ParseFloat(),與上面一致,不贅述。
3.轉(zhuǎn)化為布爾值
書(shū)寫(xiě)方式為Boolean(),如果上面的隱式轉(zhuǎn)換你有好好看,這里很得不需要再寫(xiě)了。
藍(lán)藍(lán)設(shè)計(jì)的小編 http://tweetduck.com