下面js教程栏目给大家介绍8个编写javascript代码的技巧和窍门。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
推荐教程:《JavaScript视频教程》
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("") .map((s, i) => `${i + 1}. ${s}`) .join("");makeList`Hello, WorldHello, World`;// 1. Hello// 2. World
登录后复制
7. 像变戏法一样交换变量的值
通过解构赋值语法,可以轻松地交换变量。
let a = "hello";let b = "world";// 错误 ❌a = bb = 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 的新增特性。
原文地址:https://dev.to/gigantz/9-javascript-tips-tricks-to-code-like-a-wizard-559i作者:Orkhan Jafarov译文地址:https://segmentfault.com/a/1190000030697379
更多编程相关知识,请访问:编程课程!!
以上就是8个编写优秀JS代码的技巧和窍门(分享)的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2724290.html