- TypeScript 简介与优势
- TypeScript 安装与使用
- TypeScript 变量声明
- TypeScript 基础类型
- TypeScript BigInt
- TypeScript Symbol
- TypeScript 元组(Tuple)
- TypeScript 枚举(Enum)
- TypeScript Never 与 Unknown
- TypeScript 接口(Interface)
- TypeScript 类(Class)
- TypeScript 函数(Function)
- TypeScript 字面量类型
- TypeScript 类型推断
- TypeScript 类型断言
- TypeScript 类型保护
- TypeScript 泛型(Generic)
- TypeScript 类型兼容性
- TypeScript 交叉类型
- TypeScript 联合类型
- TypeScript 类型别名
- TypeScript 索引类型
- TypeScript 映射类型
- TypeScript 条件类型
- TypeScript is 关键字
- TypeScript infer 关键字
- TypeScript Truthy 与 Falsy
- TypeScript 迭代器(Iterator)
- TypeScript 生成器(Generator)
- TypeScript 装饰器(Decorator)
- TypeScript Reflect Metadata
- TypeScript 混入(Mixins)
- TypeScript 模块
- TypeScript 命名空间
- TypeScript 声明合并
- TypeScript 编译选项
- TypeScript tsconfig.json 配置
- TypeScript TSLint 与 ESLint
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
TypeScript Truthy 与 Falsy
除了明确的 true 和 false 两个 boolean 类型外,JavaScript 可以在需要用到布尔类型值的上下文中使用强制类型转换将值转换为布尔值。
1. 慕课解释
Truthy 指的是转换后的值为’真‘的值,Falsy 是在 Boolean 上下文中已认定可转换为‘假‘的值。
变量类型 | Truthy | Falsy |
---|---|---|
boolean | true | false |
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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论