利用ES6中的...扩展运算符来合并数组

简介: 本文介绍了使用ES6的新特性简化JavaScript编程的多种方法。其中包括使用扩展运算符`...`优雅地合并数组,解构赋值快速提取数组和对象值,`for...of`循环及箭头函数提升数组遍历效率,`find`方法简化数组搜索,`+`号与短路运算符优化数据类型转换及默认值设置,以及模板字符串和扩展运算符增强的对象合并技巧,这些方法让代码更加简洁高效。

利用ES6中的...扩展运算符来合并数组
1、数组合并
常规写法

利用concat方法来合并数组

const apples = ["红苹果", "绿苹果"];
const fruits = ["西瓜", "草莓", "葡萄"].concat(apples);
console.log(fruits); // ['西瓜', '草莓', '葡萄', '红苹果', '绿苹果']
优雅写法

利用ES6中的...扩展运算符来合并数组

const apples = ["红苹果", "绿苹果"];
const fruits = ["西瓜", "草莓", "葡萄", ...apples];
console.log(fruits);//['西瓜', '草莓', '葡萄', '红苹果', '绿苹果']
2、数组中取值
常规写法

利用数组下标一个一个从数组中取数据

const num = [1, 2];
const num1 = num[0];
const num2 = num[1];
console.log(num1, num2); //1 2
优雅写法

利用ES6的解构赋值来取值

const num = [1, 2];
const [num1, num2] = num;
console.log(num1, num2);
3、对象取值
常规写法

对象.属性名 的方式获取属性值

const user = {
name: "张三",
age: 30,
};
const name = user.name;
const age = user.age;
console.log(name, age);//"张三" 30
优雅写法

利用ES6的解构赋值来实现

const user = {
name: "张三",
age: 30,
};
const { name, age } = user;
console.log(name, age); // 张三 30
4、数组循环
常规写法

利用for循环来遍历数组,从而取值

const fruits = ["西瓜", "草莓", "葡萄", "苹果"];
for (let i = 0; i < fruits.length; i++) {
console.log(fruits[i]);
}
优雅写法

利用ES6的for ... of来遍历数组取值

const fruits = ["西瓜", "草莓", "葡萄", "苹果"];
for (fruit of fruits) {
console.log(fruit);
}
5、回调函数
常规写法

forEach中回调函数为普通函数

const fruits = ["西瓜", "草莓", "葡萄", "苹果"];
fruits.forEach(function (fruit) {
console.log(fruit); //西瓜 草莓 葡萄 苹果
});
优雅写法

forEach中回调函数为箭头函数,如果箭头函数中只有一句代码,则可以省略{ }

const fruits = ["西瓜", "草莓", "葡萄", "苹果"];
fruits.forEach((fruit) => console.log(fruit)); //西瓜 草莓 葡萄 苹果https://beijing.92demo.com/sitemap
6、数组搜索
常规写法

数组中保存着每一条水果的信息,我们通过输入水果名,到数组中查找到对应的信息。

利用常规的for循环遍历来查找。

const fruits = [
{ name: "苹果", order: 1 },
{ name: "李子", order: 4 },
{ name: "香蕉", order: 2 },
];
function getApples(arr, value) {
for (let index = 0; index < arr.length; index++) {
if (arr[index].name === value) {
return arr[index];
}
}
}
const result = getApples(fruits, "苹果");
console.log(result); // { name: "苹果", order: 1 }
优雅写法

利用数组的find方法来实现搜索

const fruits = [
{ name: "苹果", order: 1 },
{ name: "李子", order: 4 },
{ name: "香蕉", order: 2 },
];
function getApples(arr, value) {
return arr.find((obj) => obj.name === value);
}
const result = getApples(fruits, "李子");
console.log(result);

//代码效果参考:https://shaoguan.92demo.com/sitemap
7、字符串转换为数字
常规写法

利用parseInt来实现

const num = parseInt("10");
console.log(num,typeof num); // 10 "number"
优雅写法

利用+ 号来实现,不过只针对纯数字的字符串有效

const num = +"10";https://shenyang.92demo.com/sitemap
console.log(num,typeof num); //=> 10 "number"
console.log(+"10" === 10); // true;
8、null值初始化
常规写法

通过if判断,如果为null,则初始化值为“普通用户”

//获取用户角色
function getUserRole(role) {
let userRole;
if (role) {
userRole = role;
} else {
userRole = "普通用户";
}
return userRole;
}
console.log(getUserRole()); //普通用户
console.log(getUserRole("管理员")); //管理员
优雅写法

通过 || 或短路运算符来实现

function getUserRole(role) {
return role || "普通用户"; // 默认值定义的常见方法
}
console.log(getUserRole()); // "普通用户"
console.log(getUserRole("管理员")); // "管理员";
9、字符串拼接
常规写法

const name = "张三";
const age = 23;
const message = "大家好,我叫" + name + "今年" + age + "岁了!";
console.log(message); //大家好,我叫张三,今年23岁了!
优雅写法

const name = "张三";
const age = 23;
const message = 大家好,我叫${name},今年${age}岁了!;
console.log(message); // Hi DevPoint!
10、对象合并:https://linyi.92demo.com/sitemap
常规写法

利用for循环来遍历

const employee = { name: "张三", age: 30 };
const salary = { grade: "A" };
const summary = salary; //用来做合并后对象
for (const key in employee) {
summary[key] = employee[key];
}
console.log(summary); // {grade: 'A', name: '张三', age: 30}
优雅写法

利用es6的扩展运算符和解构赋值来实现

const employee = { name: "张三", age: 30 };
const salary = { grade: "A" };
const summary = { ...employee, ...salary };
console.log(summary); // { name: '张三', age: 30, grade: 'A' }

相关文章
|
4月前
|
JavaScript
|
1月前
|
存储 JavaScript 前端开发
es6 扩展运算符
【8月更文挑战第20天】
8 0
|
1月前
|
存储 API
ES6新增语法 扩展运算符
ES6新增语法 扩展运算符
21 0
|
1月前
|
JavaScript 前端开发 网络架构
ES6新特性: 默认参数及扩展运算符和剩余参数
ES6新特性: 默认参数及扩展运算符和剩余参数
|
3月前
|
C# 数据库
C#中的空合并运算符与空合并赋值运算符:简化空值处理
C#中的空合并运算符与空合并赋值运算符:简化空值处理
|
JavaScript 前端开发 安全
ES6(数值的扩展)
ES6(数值的扩展)
63 0
|
4月前
|
前端开发 JavaScript Java
ES6中将非数组转换为数组的三种方法
ES6中将非数组转换为数组的三种方法
|
10月前
es6扩展运算符、concat方法合并多个数组
es6扩展运算符、concat方法合并多个数组
43 0
|
9月前
|
网络架构
ES6学习(五)—数组的扩展
ES6学习(五)—数组的扩展
|
10月前
ES6中数值扩展
ES6中数值扩展
34 0