JavaScript 特殊运算符有哪些?

JavaScript 特殊运算符有哪些?
整理了一些前端学习资料,需要的免费领取。
直通车

众多编程语言之中JavaScript ,以其强大而全面的功能深受前端开发者喜爱。其丰富的运算符集,不仅包括了广泛应用的算术运算符、比较运算符以及逻辑运算符,还蕴藏着一系列较为冷门但同样功能强大的运算符。这些不常被提及的运算符,或许因它们特定的应用场景或是相对少见的使用频率,而未能广泛进入开发者的视野。然而,深入了解并掌握这些运算符,无疑能够为我们的开发工作增添更多的便利与高效。接下来,让我们一同了解下哪些冷漠且很适用的运算符~

在这里插入图片描述

特殊运算符号有哪些?

1. ??(空值合并运算符)

空值合并运算符 ?? 用于当左侧操作数为 nullundefined 时,返回右侧操作数。

let x = null;
let y = 'default';
let z = x ?? y; // z 的值为 'default'
console.log(z); // 输出: default

2. ??=(空值合并赋值运算符)

空值合并赋值运算符 ??= 用于当左侧变量为 nullundefined 时,将右侧的值赋给左侧的变量。

let x = null;
let y = 'value';
x ??= y; // x 的值变为 'value'
console.log(x); // 输出: value

3. ?.(可选链运算符)

可选链运算符 ?. 允许我们安全地访问深层嵌套的属性,而不用担心中间某个属性是 nullundefined

let user = { name: 'Alice', address: { city: 'Wonderland' } };
let city = user?.address?.city; // city 的值为 'Wonderland'
console.log(city); // 输出: Wonderland

let nullUser = null;
let nullCity = nullUser?.address?.city; // nullCity 的值为 undefined
console.log(nullCity); // 输出: undefined

4. ?=(三元运算符的简洁形式?实际上应称为逻辑空赋值运算符的误解)

注意:这里有一个小误区,?= 并不是三元运算符的简洁形式,而是逻辑空赋值运算符(Logical Nullish Assignment ??=)的一部分,已在上面介绍。真正的三元运算符是 ?:,用于简单的条件判断。

let age = null;
age = age ? age : 18; // 传统三元运算符用法,如果 age 为 null 或 undefined,则赋值为 18
console.log(age); // 输出: 18

// 使用 ??= 简化
let age2 = null;
age2 ??= 18; // 如果 age2 为 null 或 undefined,则赋值为 18
console.log(age2); // 输出: 18

5. typeof(类型运算符)

typeof 运算符用于判断一个变量的类型。

let x = 'Hello, world!';
console.log(typeof x); // 输出: string

let y = 42;
console.log(typeof y); // 输出: number

let z = true;
console.log(typeof z); // 输出: boolean

let u;
console.log(typeof u); // 输出: undefined

6. instanceof(实例运算符)

instanceof 运算符用于测试一个对象是否在其原型链原型上具有一个构造函数的 prototype 属性。

class Animal { }
class Dog extends Animal { }

let dog = new Dog();
console.log(dog instanceof Dog); // 输出: true
console.log(dog instanceof Animal); // 输出: true

7. in(属性运算符)

in 运算符用于检查对象是否具有指定的属性。

let obj = { a: 1, b: 2 };
console.log('a' in obj); // 输出: true
console.log('c' in obj); // 输出: false

8. delete(删除运算符)

delete 运算符用于删除对象的属性。

let obj = { a: 1, b: 2 };
delete obj.a;
console.log(obj); // 输出: { b: 2 }

9. void(空运算符)

void 运算符用于计算一个表达式,并返回 undefined 作为结果。

let x = void (0); // x 的值为 undefined
console.log(x); // 输出: undefined

10. ,(逗号运算符)

逗号运算符用于评估两个表达式,并返回最后一个表达式的结果。

let x = (1, 2); // x 的值为 2
console.log(x); // 输出: 2

面试技巧

1. 理解并熟悉每个运算符的用途、优点

在面试中,对 JavaScript 运算符的深刻理解能够帮助你快速解决算法问题,并写出更简洁、高效的代码。

2. 注意运算符的优先级和结合性

了解运算符的优先级和结合性(即运算顺序)对于避免逻辑错误至关重要。例如,*(乘法)的优先级高于 +(加法)。

3. 使用可选链运算符简化代码

在访问嵌套对象属性时,使用可选链运算符 ?. 可以避免繁琐的条件检查,使代码更简洁、易读。

4. 利用空值合并运算符处理默认值

在处理可能为 nullundefined 的变量时,使用空值合并运算符 ?? 可以方便地设置默认值,减少代码冗余。

5. 掌握三元运算符的简洁写法

三元运算符 ?: 是条件判断的一种简洁写法,可以在一行内完成简单的条件逻辑,使代码更加紧凑。

6. 理解 typeofinstanceof 的区别

typeof 用于判断变量类型,而 instanceof 用于判断对象是否是某个构造函数的实例,两者在用途上有所不同。

7. 谨慎使用 delete 运算符

delete 运算符可以删除对象的属性,但删除数组元素时应谨慎,因为它不会改变数组长度,只是将元素值设置为 undefined

8. 熟悉逗号运算符的用途

逗号运算符在某些情况下可以简化代码,例如在 for 循环中同时更新多个变量。

9. 利用 void 运算符避免不必要的返回值

void 运算符可以用于避免函数或表达式返回不必要的值,确保代码逻辑的清晰性。

看到这里的小伙伴,欢迎点赞、评论,收藏!

如有前端相关疑问,博主会在第一时间解答,也同样欢迎添加博主好友,共同进步!!!

<< JavaScript 中的数据类型分为两大类:**基本数据类型(Primitive Types)** 和 **引用数据类型(Reference/Complex Types)**。 ### 基本数据类型 (Primitive Types) 这些类型的值是不可变的,并且直接存储在栈内存中。它们包括以下几种: 1. **String**: 表示文本字符串。 ```javascript let str = "Hello, World!"; ``` 2. **Number**: 包括整数、浮点数等所有数字形式,没有单独的 `int` 或者 `float` 类型区分。(从 ES6 开始还引入了 BigInt) ```javascript let num = 42; ``` 3. **BigInt**: 是一种新的数值类型,用于表示任意精度的大整数。 ```javascript let bigIntNum = 9007199254740991n; // 注意 n 后缀 ``` 4. **Boolean**: 只有两个可能的布尔值 true 或 false。 ```javascript let boolVal = true; ``` 5. **Undefined**: 当变量未被赋值时,默认为 undefined;此外也用来表明某个属性不存在或尚未定义。 ```javascript let undeclaredVar; console.log(undeclaredVar); // 输出undefined ``` 6. **Null**: 显式地表示“无任何对象值”,即有意设置为空指针的情况下的特殊标识符 null。 ```javascript let obj = null; ``` 7. **Symbol**: (ES6 引入),创建独一无二的符号作为键使用,在对象内部防止命名冲突非常有用。 ```javascript const sym = Symbol("description"); ``` --- ### 引用数据类型 (Reference Types / Complex Types) 与基础数据类型不同的是,复杂数据结构通常保存在其自己的堆空间内,而变量实际上指向该位置的一个地址而不是实际内容本身。这使得多个变量能够共享相同的底层数据资源成为可能。 主要包括以下几项: 1. **Object** - 对象是一组包含零个或更多名-值对儿组成的集合体,其中名字必须是字符串或者 Symbols。 ```javascript var person = { name: 'Alice', age: 30 }; ``` 2. **Array** 数组本质上也是一种特殊的 Object 实例,不过它是有序列表的形式存在而已。数组元素可以通过索引来访问。 ```javascript let arr = [1, 2, 3]; ``` 3. **Function** 函数同样被视为一阶公民的对象并且具备可调用的能力,因此也被认为是一种复合类型的一种特殊情况。 ```javascript function greet() { return "Hello"; } ``` 4. **Date**, **RegExp**(正则表达式) 等其他内置构造器生成的实例也可以归为此类别下。 --- ### 特殊情况说明 需要注意的一点是虽然上面提到过 Null 和 Undefined 属于简单数据类型但是 typeof 运算符对于这两个关键字会返回不同的结果: ```javascript typeof(null); // 返回 object ,这是一个历史遗留错误! typeof(undefined); // 正确返回 "undefined" ``` 这种异常行为是因为早期 JavaScript 设计中的 bug 所导致的结果一直沿袭至今未能修正以免破坏现有脚本兼容性考虑所致。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值