共计 2357 个字符,预计需要花费 6 分钟才能阅读完成。
作者:Orkhan Jafarov
翻译:疯狂的技术宅
原文:https://dev.to/gigantz/9-java…
未经容许严禁转载
1. 生成指定区间内的数字
有时候须要创立在某个数字范畴内的数组。比方在抉择生日时。以下是最简略的实现办法。
let start = 1900,
end = 2000;
[...new Array(end + 1).keys()].slice(start);
// [1900, 1901, ..., 2000]
// 也能够这样,然而大范畴后果不稳固
Array.from({length: end - start + 1}, (_, i) => start + i);
2. 把值数组中的值作为函数的参数
有时候咱们须要先把值放到数组中,而后再作为函数的参数进行传递。应用 ES6 语法能够只凭借扩大运算符(...
)就能够把值从数组中提取进去:[arg1,arg2] => (arg1,arg2)
。
const parts = {first: [0, 2],
second: [1, 3],
};
["Hello", "World", "JS", "Tricks"].slice(...parts.second);
// ["World", "JS", "Tricks"]
这个技巧在任何函数中都实用,请持续看第 3 条。
3. 把值数组中的值作为 Math 办法的参数
当须要在数组中找到数字的最大或最小值时,能够像上面这样做:
// 查到元素中的 y 地位最大的那一个值
const elementsHeight = [...document.body.children].map(el => el.getBoundingClientRect().y
);
Math.max(...elementsHeight);
// 输入最大的那个值
const numbers = [100, 100, -1000, 2000, -3000, 40000];
Math.min(...numbers);
// -3000
4. 展平嵌套数组
Array 有一个名为 Array.flat
的办法,它须要一个示意深度的参数来展平嵌套数组(默认值为 1)。然而如果你不晓得深度怎么办,这时候只须要将 Infinity
作为参数即可。另外还有一个很好用的 flatMap 办法。
const arrays = [[10], 50, [100, [2000, 3000, [40000]]]];
arrays.flat(Infinity);
// [10, 50, 100, 2000, 3000, 40000]
5. 避免代码解体
如果在代码中存在不可预测的行为,结果是难以预料的,所以须要对其进行解决。
例如当你想要获取的属性为 undefined
或 null
时,会失去 TypeError
谬误。
如果你的我的项目代码不反对可选链(optional chaining)的话,能够这样做:
const found = [{name: "Alex"}].find(i => i.name === 'Jim');
console.log(found.name);
// TypeError: Cannot read property 'name' of undefined
能够这样防止
const found = [{name: "Alex"}].find(i => i.name === 'Jim') || {};
console.log(found.name);
// undefined
不过这要视状况而定,对于小规模的代码进行解决齐全没什么问题。不须要太多代码就能够解决它。
6. 传参的好办法
在 ES6 中能够把 模板字面量(Template literal) 当作是不带括号的函数的参数。这在进行格式化或转换文本的时十分好用。
const makeList = (raw) =>
raw
.join()
.trim()
.split("\n")
.map((s, i) => `${i + 1}. ${s}`)
.join("\n");
makeList`
Hello, World
Hello, World
`;
// 1. Hello
// 2. World
7. 像变戏法一样替换变量的值
通过解构赋值语法,能够轻松地替换变量。
let a = "hello";
let b = "world";
// 谬误 ❌
a = b
b = a
// {a: 'world', b: 'world'}
// 正确 ✅
[a, b] = [b, a];
// {a: 'world', b: 'hello'}
8. 遮蔽字符串
某些时候咱们须要遮蔽字符串的一部分,当然不只是对明码做这种操作。上面代码中通过 substr(-3)
失去字符串的一部分,即从字符串开端开始往前 3 个字符,而后再用你喜爱的字符填充残余的地位(比如说用 *
)
const password = "hackme";
password.substr(-3).padStart(password.length, "*");
// ***kme
结语
在编码时还须要放弃代码整洁,平时留神积攒在编码时所使到的技巧,并关注 JavaScript 的新增个性。
本文首发微信公众号:前端先锋
欢送扫描二维码关注公众号,每天都给你推送陈腐的前端技术文章
欢送持续浏览本专栏其它高赞文章:
- 深刻了解 Shadow DOM v1
- 一步步教你用 WebVR 实现虚拟现实游戏
- 13 个帮你进步开发效率的古代 CSS 框架
- 疾速上手 BootstrapVue
- JavaScript 引擎是如何工作的?从调用栈到 Promise 你须要晓得的所有
- WebSocket 实战:在 Node 和 React 之间进行实时通信
- 对于 Git 的 20 个面试题
- 深刻解析 Node.js 的 console.log
- Node.js 到底是什么?
- 30 分钟用 Node.js 构建一个 API 服务器
- Javascript 的对象拷贝
- 程序员 30 岁前月薪达不到 30K,该何去何从
- 14 个最好的 JavaScript 数据可视化库
- 8 个给前端的顶级 VS Code 扩大插件
- Node.js 多线程齐全指南
- 把 HTML 转成 PDF 的 4 个计划及实现
- 更多文章 …