做者:Orkhan Jafarov翻译:疯狂的技术宅javascript
原文:https://dev.to/gigantz/9-java...前端
未经容许严禁转载java
有时候须要建立在某个数字范围内的数组。好比在选择生日时。如下是最简单的实现方法。程序员
let start = 1900, end = 2000; [...new Array(end + 1).keys()].slice(start); // [ 1900, 1901, ..., 2000] // 也能够这样,可是大范围结果不稳定 Array.from({ length: end - start + 1 }, (_, i) => start + i);
有时候咱们须要先把值放到数组中,而后再做为函数的参数进行传递。使用 ES6 语法能够只凭借扩展运算符(...
)就能够把值从数组中提取出来: [arg1,arg2] => (arg1,arg2)
。面试
const parts = { first: [0, 2], second: [1, 3], }; ["Hello", "World", "JS", "Tricks"].slice(...parts.second); // ["World", "JS", "Tricks"]
这个技巧在任何函数中都适用,请继续看第 3 条。segmentfault
当须要在数组中找到数字的最大或最小值时,能够像下面这样作:数组
// 查到元素中的 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
Array 有一个名为 Array.flat
的方法,它须要一个表示深度的参数来展平嵌套数组(默认值为 1)。可是若是你不知道深度怎么办,这时候只须要将 Infinity
做为参数便可。另外还有一个很好用的 flatMap 方法。服务器
const arrays = [[10], 50, [100, [2000, 3000, [40000]]]]; arrays.flat(Infinity); // [ 10, 50, 100, 2000, 3000, 40000 ]
若是在代码中存在不可预测的行为,后果是难以预料的,因此须要对其进行处理。微信
例如当你想要获取的属性为 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
不过这要视状况而定,对于小规模的代码进行处理彻底没什么问题。不须要太多代码就能够处理它。
在 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
经过解构赋值语法,能够轻松地交换变量。
let a = "hello"; let b = "world"; // 错误 ❌ a = b b = a // { a: 'world', b: 'world' } // 正确 ✅ [a, b] = [b, a]; // { a: 'world', b: 'hello' }
某些时候咱们须要遮蔽字符串的一部分,固然不仅是对密码作这种操做。下面代码中经过 substr(-3)
获得字符串的一部分,即从字符串末尾开始往前 3 个字符,而后再用你喜欢的字符填充剩余的位置(好比说用 *
)
const password = "hackme"; password.substr(-3).padStart(password.length, "*"); // ***kme
在编码时还须要保持代码整洁,平时注意积累在编码时所使到的技巧,并关注 JavaScript 的新增特性。