10种JavaScript代码优雅写法

简介: 10种JavaScript代码优雅写法

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)); //西瓜 草莓 葡萄 苹果
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);

//代码效果参考:http://wap.huayi1997.com/sitemap/post1.html
7、字符串转换为数字
常规写法

利用parseInt来实现

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

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

const num = +"10";
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、对象合并
常规写法

利用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' }

相关文章
|
3月前
|
JavaScript
短小精悍的js代码
【10月更文挑战第17天】
135 58
|
3月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。
【10月更文挑战第7天】随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。通过安装和配置这两个工具,可以确保代码风格一致,提升团队协作效率和代码质量。
282 2
|
3月前
|
JavaScript 前端开发 内存技术
js文件的入口代码及需要入口代码的原因
js文件的入口代码及需要入口代码的原因
47 0
|
30天前
|
JavaScript 前端开发 测试技术
在 golang 中执行 javascript 代码的方案详解
本文介绍了在 Golang 中执行 JavaScript 代码的四种方法:使用 `otto` 和 `goja` 嵌入式 JavaScript 引擎、通过 `os/exec` 调用 Node.js 外部进程以及使用 WebView 嵌入浏览器。每种方法都有其适用场景,如嵌入简单脚本、运行复杂 Node.js 脚本或在桌面应用中显示 Web 内容。
73 15
在 golang 中执行 javascript 代码的方案详解
|
4月前
|
编解码 前端开发 JavaScript
javascript检测网页缩放演示代码
javascript检测网页缩放演示代码
|
2月前
|
JavaScript
原生js炫酷随机抽奖中奖效果代码
原生js随机抽奖是一个炫酷的根据数据随机抽奖的代码,该网页可进行随机抽取一个数据,页面动画高科技、炫酷感觉的随机抽奖效果,简单好用,欢迎下载!
48 3
|
2月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
551 4
|
2月前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
130 6
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例