「TypeScript系列」TypeScript 运算符

一、TypeScript 运算符

TypeScript 是 JavaScript 的一个超集,它增加了类型系统和编译时类型检查。然而,在运算符方面,TypeScript 继承了 JavaScript 的大部分运算符。以下是一些在 TypeScript(和 JavaScript)中常见的运算符:

  1. 算术运算符
  • + 加法
  • - 减法
  • * 乘法
  • / 除法
  • % 取余(模运算)
  • ** 幂运算(ES2016+)
  • ++ 自增
  • -- 自减
  • +=-=*=/=%=**= 复合赋值运算符
  1. 比较运算符
  • == 等于(会进行类型转换)
  • === 严格等于(不会进行类型转换)
  • != 不等于(会进行类型转换)
  • !== 严格不等于(不会进行类型转换)
  • < 小于
  • > 大于
  • <= 小于或等于
  • >= 大于或等于
  • in 检查属性是否存在于对象中
  • instanceof 检查对象是否是某个类的实例
  1. 逻辑运算符
  • && 逻辑与
  • || 逻辑或
  • ! 逻辑非
  1. 位运算符
  • & 按位与
  • | 按位或
  • ^ 按位异或
  • ~ 按位非
  • << 左移
  • >> 右移
  • >>> 无符号右移(ES2015+)
  1. 字符串运算符
  • + 用于连接两个或多个字符串(或者连接字符串和数字)
  1. 条件(三元)运算符
  • condition ? value_if_true : value_if_false
  1. 赋值运算符
  • = 赋值
  • 复合赋值运算符(如上面算术运算符中提到的那些)
  1. 类型运算符
  • typeof 返回操作数的类型(在 TypeScript 中,这更多地与 JavaScript 相关,但在某些上下文中仍然有用)
  • as 类型断言(TypeScript 特有的)
  • <Type>value 类型断言(另一种 TypeScript 语法,与 as 等效)
  1. 指数运算符
  • ** 幂运算(ES2016+)
  1. 扩展运算符
  • ... 用于函数参数(收集剩余参数)或数组(展开数组)
  1. 可选链运算符
  • ?. 尝试获取对象属性或调用函数,如果左侧为 null 或 undefined 则立即返回 undefined,而不会抛出错误(ES2020+)
  1. 空值合并运算符
  • ?? 如果左侧操作数为 null 或 undefined,则返回其右侧操作数;否则返回左侧操作数(ES2020+)

注意:一些运算符(如 ****=???.)是 ES2016 或更新版本的标准中引入的,但在 TypeScript 中通常也可以使用,因为 TypeScript 支持这些较新的 JavaScript 功能。

二、TypeScript 算术运算符

TypeScript 的算术运算符与 JavaScript 中的算术运算符是相同的,因为 TypeScript 是 JavaScript 的一个超集。以下是一些使用 TypeScript 算术运算符的示例:

1. 基本算术运算

let a: number = 10;
let b: number = 2;

let sum: number = a + b;  // 加法
console.log(sum);  // 输出 12

let difference: number = a - b;  // 减法
console.log(difference);  // 输出 8

let product: number = a * b;  // 乘法
console.log(product);  // 输出 20

let quotient: number = a / b;  // 除法
console.log(quotient);  // 输出 5

let remainder: number = a % b;  // 取余
console.log(remainder);  // 输出 0

2. 复合赋值运算符

let x: number = 5;

x += 3;  // 等同于 x = x + 3
console.log(x);  // 输出 8

x -= 2;  // 等同于 x = x - 2
console.log(x);  // 输出 6

x *= 2;  // 等同于 x = x * 2
console.log(x);  // 输出 12

x /= 2;  // 等同于 x = x / 2
console.log(x);  // 输出 6

x %= 3;  // 等同于 x = x % 3
console.log(x);  // 输出 0

3. 自增和自减运算符

let y: number = 5;

y++;  // 等同于 y = y + 1
console.log(y);  // 输出 6

++y;  // 等同于 y = y + 1
console.log(y);  // 输出 7

y--;  // 等同于 y = y - 1
console.log(y);  // 输出 6

--y;  // 等同于 y = y - 1
console.log(y);  // 输出 5

4. 幂运算符

虽然幂运算符 (**) 是 ES2016 引入的,但 TypeScript 也支持它。

let base: number = 2;
let exponent: number = 3;

let result: number = base ** exponent;  // 幂运算
console.log(result);  // 输出 8

在编写这些示例时,请确保您有一个可以运行 TypeScript 代码的环境,比如使用 TypeScript 编译器 (tsc) 将 TypeScript 代码编译为 JavaScript,然后在支持这些运算符的 JavaScript 环境中运行生成的 JavaScript 代码。如果您使用的是现代的开发环境(如 Node.js、Angular、React 等),这些环境通常已经内置了对 TypeScript 的支持。

三、TypeScript 关系运算符

TypeScript 的关系运算符(也称为比较运算符)用于比较两个值的大小或检查它们是否相等。以下是一些使用 TypeScript 关系运算符的示例代码:

let a: number = 10;
let b: number = 5;
let c: string = "hello";
let d: string = "world";

// 相等性比较
console.log(a == b);  // 宽松相等,输出 false
console.log(a === b); // 严格相等,输出 false
console.log(c == d);  // 宽松相等(会进行类型转换尝试),输出 false
console.log(c === d); // 严格相等,输出 false

// 不等性比较
console.log(a != b);  // 宽松不等,输出 true
console.log(a !== b); // 严格不等,输出 true

// 数值比较
console.log(a > b);    // 大于,输出 true
console.log(a < b);    // 小于,输出 false
console.log(a >= b);   // 大于或等于,输出 true
console.log(a <= b);   // 小于或等于,输出 false

// 字符串比较(按字符顺序比较)
console.log(c < d);    // 按字符顺序比较,输出 true(因为 'h' 在 'w' 前面)
console.log(c > d);    // 按字符顺序比较,输出 false

// in 运算符(用于检查属性是否存在于对象中)
let obj: { prop: number } = { prop: 15 };
console.log("prop" in obj); // 输出 true

// instanceof 运算符(用于检查对象是否是某个类的实例)
class MyClass {}
let instance: MyClass = new MyClass();
console.log(instance instanceof MyClass); // 输出 true

// 注意:'in' 和 'instanceof' 不是严格意义上的关系运算符,但它们在比较场景中很常见

这些示例展示了如何在 TypeScript 中使用关系运算符来比较数值和字符串,以及如何使用 ininstanceof 运算符来检查对象属性和类的实例。请注意,ininstanceof 不是传统意义上的关系运算符,但它们在比较操作中也起着重要的作用。

四、TypeScript 逻辑运算符

TypeScript 的逻辑运算符用于根据操作数的逻辑值(真或假)返回一个新的逻辑值。这些运算符在 TypeScript 中与 JavaScript 中的用法相同。以下是使用 TypeScript 逻辑运算符的示例代码:

let isRaining: boolean = true;
let haveUmbrella: boolean = false;
let shouldWearRainBoots: boolean;

// 逻辑与(&&)
// 如果两个操作数都为真,则条件为真
shouldWearRainBoots = isRaining && !haveUmbrella; // 如果没有伞并且下雨,则应该穿雨靴
console.log(shouldWearRainBoots); // 输出 true

// 逻辑或(||)
// 如果任一操作数为真,则条件为真
haveUmbrella = true; // 假设我们现在有一把伞
shouldWearRainBoots = isRaining || !haveUmbrella; // 如果下雨或没有伞,则应该穿雨靴
console.log(shouldWearRainBoots); // 输出 true(因为下雨)

// 逻辑非(!)
// 反转操作数的逻辑值
isRaining = !isRaining; // 如果之前下雨,现在就不下了
console.log(isRaining); // 输出 false

// 复杂逻辑表达式
let age: number = 18;
let isAdult: boolean = age >= 18; // 判断是否成年
let canVote: boolean = isAdult && isRaining; // 假设只有成年且下雨时才能投票(这是一个不符合实际的假设)
console.log(canVote); // 输出 false(因为现在没有下雨)

// 使用括号来明确优先级
let canDrinkAlcohol: boolean = (age >= 21) && isRaining; // 假设只有年龄大于等于 21 且下雨时才能喝酒
console.log(canDrinkAlcohol); // 输出 false(因为现在没有下雨)

在这个示例中,我们使用了 &&(逻辑与)、||(逻辑或)和 !(逻辑非)运算符来根据变量的逻辑值计算结果。我们还使用了括号来明确运算符的优先级,这在处理复杂的逻辑表达式时非常重要。

请注意,在 TypeScript(以及 JavaScript)中,逻辑运算符的操作数通常是布尔值(truefalse),但也可以是非布尔值。非布尔值会被隐式转换为布尔值(也称为“真值化”或“假值化”),其中 0nullundefinedNaN 和空字符串("")被视为 false,而其他所有值都被视为 true

五、TypeScript 位运算符

TypeScript 中的位运算符用于在二进制位级别上操作数字。这些运算符在处理整数和底层系统编程时特别有用。以下是一些使用 TypeScript 位运算符的示例代码:

let a: number = 60; // 二进制表示为 0011 1100
let b: number = 13; // 二进制表示为 0000 1101

// 位与(&)
let c: number = a & b; // 只保留两个数都为 1 的位,结果为 12(0000 1100)
console.log(c); // 输出 12

// 位或(|)
let d: number = a | b; // 只要两个数中任一数为 1 的位,结果就是 1,结果为 61(0011 1101)
console.log(d); // 输出 61

// 位异或(^)
let e: number = a ^ b; // 当两个数相应位不同时结果为 1,相同则为 0,结果为 49(0011 0001)
console.log(e); // 输出 49

// 位非(~)
let f: number = ~a; // 反转每一位,结果取决于数字的长度和表示方式(通常是有符号 32 位整数),这里可能是 -61
console.log(f); // 输出 -61,具体值取决于系统的位表示和整数大小

// 左移(<<)
let g: number = a << 2; // 将 a 的所有位向左移动 2 位,相当于乘以 2^2(4),结果为 240(1111 0000)
console.log(g); // 输出 240

// 右移(>>)
let h: number = a >> 1; // 将 a 的所有位向右移动 1 位,相当于除以 2(并向下取整),结果为 30(0001 1110)
console.log(h); // 输出 30

// 无符号右移(>>>)
let i: number = a >>> 2; // 将 a 的所有位向右移动 2 位,但左侧填充 0 而不是符号位,对于正数等同于 >>
console.log(i); // 输出 15(0000 1111),对于负数,符号位会被丢弃,然后填充 0

请注意,位运算符只能用于整数类型(在 TypeScript 和 JavaScript 中通常是 number 类型,但实际上是按照 32 位或 64 位整数来处理的,具体取决于实现)。

此外,由于位运算符在二进制层面操作,因此结果可能会受到 JavaScript 数字表示的限制(通常是 IEEE 754 双精度浮点数,但在位操作中会被当作 32 位有符号整数处理)。对于非常大的数字或负数,结果可能不符合直观的数学期望。

对于无符号右移运算符 >>>,它总是用 0 来填充左侧空位,不考虑原始数字的符号。这在处理无符号整数或需要保持正数结果时特别有用。

六、TypeScript 赋值运算符

在 TypeScript 中,赋值运算符(=)是最基本的运算符,用于将值赋给变量。但是,除了基本的赋值运算符外,还有一些复合赋值运算符,如 +=-=*=/=%= 等,它们允许在赋值的同时执行一些基本的算术操作。

以下是一些使用 TypeScript 赋值运算符的示例代码:

// 基本的赋值运算符
let a: number;
a = 10;
console.log(a); // 输出 10

// 复合赋值运算符
let b: number = 5;
b += 3; // 相当于 b = b + 3
console.log(b); // 输出 8

let c: number = 10;
c -= 2; // 相当于 c = c - 2
console.log(c); // 输出 8

let d: number = 2;
d *= 3; // 相当于 d = d * 3
console.log(d); // 输出 6

let e: number = 10;
e /= 2; // 相当于 e = e / 2
console.log(e); // 输出 5

let f: number = 10;
f %= 3; // 相当于 f = f % 3
console.log(f); // 输出 1

// 字符串连接赋值运算符(虽然它不是一个标准的算术运算符,但也是一种赋值)
let g: string = "Hello";
g += " World!"; // 相当于 g = g + " World!"
console.log(g); // 输出 "Hello World!"

// 递增和递减赋值运算符(虽然不是复合赋值运算符,但它们是赋值相关的)
let h: number = 5;
h++; // 相当于 h = h + 1
console.log(h); // 输出 6

let i: number = 10;
i--; // 相当于 i = i - 1
console.log(i); // 输出 9

// 链式赋值
let j: number = 10;
let k: number;
let l: number;
k = l = j; // j 的值被赋给 l,然后 l 的值(现在是 j 的值)被赋给 k
console.log(k); // 输出 10
console.log(l); // 输出 10

在这个示例中,我们展示了如何使用基本的赋值运算符(=)和复合赋值运算符(+=-=*=/=%=)来修改变量的值。我们还展示了如何使用字符串连接赋值(通过 +=)以及递增(++)和递减(--)赋值运算符。最后,我们展示了链式赋值,其中多个变量可以连续地被赋予相同的值。

七、相关链接

  1. TypeScript中文网
  2. TypeScript下载
  3. TypeScript文档
  4. 「TypeScript系列」TypeScript 简介及基础语法
  5. 「TypeScript系列」TypeScript 基础类型
  6. 「TypeScript系列」TypeScript 变量声明
评论 66
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

·零落·

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值