当前位置:主页 > 聚焦 >

8个编写优秀JS代码的技巧和窍门(分享)

时间:2020-11-12 22:24:10

  下面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); // -30004. 展平嵌套数组

  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); // 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. World7. 像变戏法一样交换变量的值

  通过解构赋值语法,可以轻松地交换变量。

  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 的新增特性。

  原文地址:

  作者:Orkhan Jafarov

  译文地址:

  编程课程!!

热点推荐
1 Chainlink:正式部署全栈基础设施以代币化

Bridgetower Capital正式部署Chainlink的全栈基础设施,以代币化与DOM X亚利桑那铜金矿项目相关的证...

2 国际海事组织:波斯湾被困海员疏散计划

消息,国际海事组织秘书长多明格斯表示,该组织正同多方共同规划波斯湾被困海员疏散计划...

3 鲸鱼地址0x527提取37.06万枚LINK,当前持有

消息,链上监测数据显示,鲸鱼地址0x527从某平台提取了370,631枚LINK,价值约348万美元,目前该...

4 埃及与巴基斯坦外长通话讨论美伊重回外

消息,埃及外长阿卜杜勒阿提于24日与巴基斯坦副总理兼外交部长达尔通电话,双方就推动美国...

5 比特币ETF总净流入达1447万美元

消息,4月24日比特币ETF总净流入为1447万美元。其中,黑石的IBIT净流入2290万美元,摩根士丹利...

6 鲸鱼0x2d2d过去7小时再购入200枚ETH,持有

鲸鱼地址0x2d2d在过去7小时内再次花费200枚ETH购买了17.2亿枚$ASTEROID。目前该地址持有8.38亿枚$...

7 Balancer黑客将14300枚ETH换成419.3枚BTC,价值

Balancer黑客从昨天开始通过Thorchain将14,300枚ETH换成419.3枚BTC,按当前价格计算约合3251万美元。目...

8 波兰加密交易所ZondaCrypto濒临破产,99%比

加密交易所ZondaCrypto的首席执行官Przemysław Kral已前往以色列,因其拥有以色列国籍,可能难以...

9 量子计算机在比特币相关测试中破解ECC密

消息,研究人员使用公共量子硬件成功破解了一个15位的椭圆曲线密钥,赢得了项目Eleven的1 ...

10 Bitget将于4月30日下架22个现货交易对

消息,Bitget宣布将于2026年4月30日上午10:00下架22个现货交易对,此举是基于定期审查的结果。用...

成都来彰科技 蜀ICP备2025134723号-1

资讯来源互联网,如有版权问题请联系管理员删除。