ToString
ToString負(fù)責(zé)處理非字符串到字符串的強(qiáng)制類型轉(zhuǎn)換,常用的字符串化方法String()、toString()。
基本類型值的字符串化規(guī)則:
普通對(duì)象在字符串化時(shí),實(shí)際執(zhí)行Object.prototype.toString(),返回該對(duì)象的類型[object type],例如:
var test = {a : 'test'}console.log(test.toString()) // '[object Object]'console.log(String(test)) // '[object Object]'
但是當(dāng)對(duì)象有自己的toString方法時(shí),字符串化時(shí)就會(huì)調(diào)用該方法并返回該方法的返回值,例如:
var obj = { a: 'test', toString: function () { return 1 }}console.log(obj.toString()) // 1console.log(String(obj)) // 1
數(shù)組在做字符串化時(shí),將數(shù)組所有元素字符串化再用","連接,例如:
var arr = [1, 2]console.log(arr.toString()) // '1,2'console.log(String(arr)) // '1,2'
JSON.stringify()
JSON.stringify()在將JSON對(duì)象序列化為字符串時(shí),也涉及到了字符串化的相關(guān)規(guī)則。
對(duì)大多數(shù)簡(jiǎn)單值來說,JSON字符串化和toString()的效果基本相同,例如:
console.log(JSON.stringify("test")) // ""test""console.log(JSON.stringify(1)) // "1"console.log(JSON.stringify(null)) // "null"
但是JSON.stringify()在對(duì)象中遇到function() {}、undefined、Symbol時(shí)會(huì)自動(dòng)將其忽略,在數(shù)組中則會(huì)返回null,例如:
var obj1 = { a: undefined, b: function () {}, c: Symbol()}console.log(JSON.stringify(obj1)) // "{}"console.log(JSON.stringify([undefined, function () {}, 1])) // "[null, mull, 1]"
當(dāng)對(duì)象執(zhí)行JSON.stringify()方法時(shí),如果對(duì)象中存在toJSON方法,用它的返回值來進(jìn)行序列化,例如:
var obj2 = { a: undefined, b: function () {}, c: Symbol(), toJSON: function () { return {a: 'replace'} }}console.log(JSON.stringify(obj2)) // "{"a":"replace"}"
ToNumber
ToNumber負(fù)責(zé)將非數(shù)字轉(zhuǎn)化為數(shù)字,Number()、parseInt()和parseFloat()都可以將非數(shù)字轉(zhuǎn)化為數(shù)字
Number()
Number()函數(shù)的轉(zhuǎn)換規(guī)則:
例如:
console.log(Number(true)) // 1console.log(Number(1)) // 1console.log(Number(null)) // 0console.log(Number(undefined)) // NaNconsole.log(Number('11')) // 11console.log(Number('1.1')) // 1.1console.log(Number('0xf')) // 15console.log(Number('')) // 0var a = { valueOf: function () { return '10' }}var b = { toString: function () { return '10' }}var c = [1, 0]c.toString = function () { return c.join("")}console.log(Number(a)) // 10console.log(Number(b)) // 10console.log(Number(c)) // 10
parseInt()
parseInt()轉(zhuǎn)換規(guī)則:
例子:
console.log(parseInt('a')) // NaNconsole.log(parseInt('11')) // 11console.log(parseInt('11aa')) // 11console.log(parseInt('0xf')) // 15
parseFloat()
parseFloat()轉(zhuǎn)換規(guī)則:
例子:
console.log(parseFloat('12.3a')) // 12.3console.log(parseFloat('0xf')) // 0console.log(parseFloat('01.1')) // 1.1
ToBoolean
布爾強(qiáng)制類型轉(zhuǎn)換的假值列表:
除了上述列表以外的值在轉(zhuǎn)換的時(shí)候都應(yīng)該是真值,強(qiáng)制布爾類型轉(zhuǎn)換常用Boolean()或者!!,第一個(gè)!將值強(qiáng)制轉(zhuǎn)為布爾類型,但同時(shí)還將真假值反轉(zhuǎn),第二個(gè)!將結(jié)果返回原值,例子:
console.log(Boolean("0")) // trueconsole.log(Boolean([])) // trueconsole.log(Boolean(undefined)) // falseconsole.log(!!"0") // trueconsole.log(!![]) // trueconsole.log(!!undefined) // false
總結(jié)
這篇文章對(duì)JS中的常見顯示強(qiáng)制類型轉(zhuǎn)換做了一個(gè)小結(jié),希望能對(duì)大家理解有所幫助。
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)武林網(wǎng)的支持。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注