返回介绍

TypeScript Truthy 与 Falsy

发布于 2020-06-05 15:08:24 字数 1844 浏览 1779 评论 0 收藏 0

除了明确的 true 和 false 两个 boolean 类型外,JavaScript 可以在需要用到布尔类型值的上下文中使用强制类型转换将值转换为布尔值。

1. 慕课解释

Truthy 指的是转换后的值为’真‘的值,Falsy 是在 Boolean 上下文中已认定可转换为‘假‘的值。

变量类型TruthyFalsy
booleantruefalse
string非空字符串‘’
number其他数字0 / NaN
null总是为假
undefined总是为假
object总是为真,包括 {}、[]、() => {}

需要注意下,空函数、空数组、空对象这些都是 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。

操作符 !! 表示变量被强制类型转换为布尔值后的值:

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. 小结

在 Vue.js 源码中有很多 !!! 的操作,如果遇到要能明白其表达的意思。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文