可以用*1來轉(zhuǎn)化為數(shù)字(實際上是調(diào)用.valueOf方法) 然后使用Number.isNaN來判斷是否為NaN,或者使用 a !== a 來判斷是否為NaN,因為 NaN !== NaN
'32' * 1 // 32'ds' * 1 // NaNnull * 1 // 0undefined * 1 // NaN1 * { valueOf: ()=>'3' } // 3常用: 也可以使用+來轉(zhuǎn)化字符串為數(shù)字
+ '123' // 123+ 'ds' // NaN+ '' // 0+ null // 0+ undefined // NaN+ { valueOf: ()=>'3' } // 3可以使用 字符串+Object 的方式來轉(zhuǎn)化對象為字符串(實際上是調(diào)用 .toString() 方法)
'the Math object:' + Math // "the Math object:[object Math]"'the JSON object:' + JSON // "the JSON object:[object JSON]"
當(dāng)然也可以覆蓋對象的toString和valueOf方法來自定義對象的類型轉(zhuǎn)換:
2 * { valueOf: ()=>'3' } // 6'J' + { toString: ()=>'S' } // "JS"《Effective JavaScript》P11:當(dāng)+用在連接字符串時,當(dāng)一個對象既有toString方法又有valueOf方法時候,JS通過盲目使用valueOf方法來解決這種含糊。
對象通過valueOf方法強(qiáng)制轉(zhuǎn)換為數(shù)字,通過toString方法強(qiáng)制轉(zhuǎn)換為字符串
'' + {toString:()=>'S',valueOf:()=>'J'} // J我們知道JS中有一些假值:false,null,0,"",undefined,NaN,怎樣把數(shù)組中的假值快速過濾呢,可以使用Boolean構(gòu)造函數(shù)來進(jìn)行一次轉(zhuǎn)換
const compact = arr => arr.filter(Boolean)compact([0, 1, false, 2, '', 3, 'a', 'e' * 23, NaN, 's', 34]) // [ 1, 2, 3, 'a', 's', 34 ]
可以使用雙位操作符來替代 Math.floor( )。雙否定位操作符的優(yōu)勢在于它執(zhí)行相同的操作運行速度更快。
Math.floor(4.9) === 4 //true// 簡寫為:~~4.9 === 4 //true
不過要注意,對整數(shù)來說 ~~ 運算結(jié)果與 Math.floor( ) 運算結(jié)果相同,而對于負(fù)數(shù)來說不相同:
~~4.5 // 4Math.floor(4.5) // 4~~-4.5 // -4Math.floor(-4.5) // -5
我們知道邏輯與&&與邏輯或||是短路運算符,短路運算符就是從左到右的運算中前者滿足要求,就不再執(zhí)行后者了; 可以理解為:
&&為取假運算,從左到右依次判斷,如果遇到一個假值,就返回假值,以后不再執(zhí)行,否則返回最后一個真值
||為取真運算,從左到右依次判斷,如果遇到一個真值,就返回真值,以后不再執(zhí)行,否則返回最后一個假值
新聞熱點
疑難解答
圖片精選