目前流行的编程语言TypeScript是在JavaScript基础上通过添加类型定义扩展而来的,而ArkTS则是TypeScript的进一步扩展。TypeScript深受开发者的喜爱,因为它提供了一种更结构化的JavaScript编码方法。ArkTS旨在保持TypeScript的大部分语法,为现有的TypeScript开发者实现无缝过渡,让移动开发者快速上手ArkTS。
ArkTS>TypeScript>JavaScript
总的来说就是ArkTS 包括了TS,JS,他两能用的,ArkTS都能用
在 JavaScript 中,!!
主要有以下作用:
一、转换为布尔值 (重点)
1.对于原始值:
- 如果值是数字,0、NaN 转换为 false,其他数字转换为true。例如:
console.log(JSON.stringify(!!0)) //false
console.log(JSON.stringify(!!9)) //true
console.log(JSON.stringify(!!NaN)) //false
- 如果值是字符串,空字符串·转换为 false,其他非空字符串转换为 true 。例如:
console.log(JSON.stringify(!!'')) //false
console.log(JSON.stringify(!!'hello'))//true
- 如果值是 null或undefined ,转换为 false 。例如:
console.log(JSON.stringify(!!null))
console.log(JSON.stringify(!!undefined))
2. 对于对象:
任何对象(包括数组、函数等)转换为 true。因为在JavaScript中,对象被认为是真值。例如:
console.log(JSON.stringify(!!(() => {}))) //true
console.log(JSON.stringify(!![])) //true
interface GeneratedObjectLiteralInterface_1 {} //函数
console.log(JSON.stringify(!!({} as GeneratedObjectLiteralInterface_1))) //true
将其他数据类型强制转换为布尔类型:在 JavaScript 中,不同的数据类型在布尔上下文中有不同的真值和假值。例如,
0
、null
、undefined
、""
(空字符串)、NaN
在布尔上下文中被视为假值,而其他值通常被视为真值。使用!!
可以将任何数据类型转换为其对应的布尔值。
二、条件判断中的应用
在条件判断中明确布尔值:有时候在条件语句中,表达式的结果可能不是明确的布尔类型。使用!!
可以确保条件判断基于明确的布尔值进行。
function checkValue(value:string|number) {
if (!!value) {
console.log(`${value} is true`);
} else {
console.log(`${value} is false`);
}
}
checkValue(0); //false
checkValue("World"); //true
注意:!!在后续华为开发文档中 表示双向绑定(以官方文档为主)
!!语法:双向绑定-其他状态管理-状态管理(V2试用版)-状态管理-学习ArkTS语言-基础入门 - 华为HarmonyOS开发者 (huawei.com)