TypeScript Truthy 與 Falsy
除了明確的 true 和 false 兩個 boolean 類型外,JavaScript 可以在需要用到布爾類型值的上下文中使用強(qiáng)制類型轉(zhuǎn)換將值轉(zhuǎn)換為布爾值。
1. 慕課解釋
Truthy 指的是轉(zhuǎn)換后的值為’真‘的值,F(xiàn)alsy 是在 Boolean 上下文中已認(rèn)定可轉(zhuǎn)換為‘假‘的值。
| 變量類型 | Truthy | Falsy |
|---|---|---|
| boolean | true | false |
| string | 非空字符串 | ‘’ |
| number | 其他數(shù)字 | 0 / NaN |
| null | 總是為假 | |
| undefined | 總是為假 | |
| object | 總是為真,包括 {}、[]、() => {} |
需要注意下,空函數(shù)、空數(shù)組、空對象這些都是 Truthy,返回 true。
2. ! 與 !!
操作符 ! 表示取反,得到一個布爾值:
let fn = () => {}
let obj = {}
let arr: never[] = []
console.log(!fn) // false
console.log(!obj) // false
console.log(!arr) // false
let num = 10
let str = 'imooc'
console.log(!num) // false
console.log(!str) // false
let n = null
let u = undefined
let N = NaN
let z = 0
console.log(!n) // true
console.log(!u) // true
console.log(!N) // true
console.log(!z) // true
解釋: 前三行的變量都是 truthy,為真,取反則得到 false。
操作符 !! 表示變量被強(qiáng)制類型轉(zhuǎn)換為布爾值后的值:
let fn = () => {}
let obj = {}
let arr: never[] = []
console.log(!!fn) // true
console.log(!!obj) // true
console.log(!!arr) // true
let num = 10
let str = 'imooc'
console.log(!!num) // true
console.log(!!str) // true
let n = null
let u = undefined
let N = NaN
let z = 0
console.log(!!n) // false
console.log(!!u) // false
console.log(!!N) // false
console.log(!!z) // false
3. 小結(jié)
在 Vue.js 源碼中有很多 ! 和 !! 的操作,如果遇到要能明白其表達(dá)的意思。
一飛同學(xué) ·
2025 imooc.com All Rights Reserved |