文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

8个写JavaScript代码的小技巧

2024-12-10 16:51

关注

[[343990]]

1. 生成指定区间内的数字

有时候需要创建在某个数字范围内的数组。比如在选择生日时。以下是最简单的实现方法。

  1. let start = 1900
  2.     end = 2000
  3. [...new Array(end + 1).keys()].slice(start); 
  4. // [ 1900, 1901, ..., 2000] 
  5.  
  6. // 也可以这样,但是大范围结果不稳定 
  7. Array.from({ length: end - start + 1 }, (_, i) => start + i); 

2. 把值数组中的值作为函数的参数

有时候我们需要先把值放到数组中,然后再作为函数的参数进行传递。使用 ES6 语法可以只凭借扩展运算符(...)就可以把值从数组中提取出来:[arg1,arg2] => (arg1,arg2)。

  1. const parts = { 
  2.   first: [0, 2], 
  3.   second: [1, 3], 
  4. }; 
  5.  
  6. ["Hello", "World", "JS", "Tricks"].slice(...parts.second); 
  7. // ["World", "JS", "Tricks"] 

这个技巧在任何函数中都适用,请继续看第 3 条。

3. 把值数组中的值作为 Math 方法的参数

当需要在数组中找到数字的最大或最小值时,可以像下面这样做:

  1. // 查到元素中的 y 位置最大的那一个值 
  2. const elementsHeight =  [...document.body.children].map( 
  3.   el => el.getBoundingClientRect().y 
  4. ); 
  5. Math.max(...elementsHeight); 
  6. // 输出最大的那个值 
  7.  
  8. const numbers = [100, 100, -1000, 2000, -3000, 40000]; 
  9. Math.min(...numbers); 
  10. // -3000 

4. 展平嵌套数组

Array 有一个名为 Array.flat 的方法,它需要一个表示深度的参数来展平嵌套数组(默认值为 1)。但是如果你不知道深度怎么办,这时候只需要将 Infinity 作为参数即可。另外还有一个很好用的 flatMap 方法。

  1. const arrays = [[10], 50, [100, [2000, 3000, [40000]]]]; 
  2. arrays.flat(Infinity); 
  3. // [ 10, 50, 100, 2000, 3000, 40000 ] 

5. 防止代码崩溃

如果在代码中存在不可预测的行为,后果是难以预料的,所以需要对其进行处理。

例如当你想要获取的属性为 undefined 或 null 时,会得到 TypeError 错误。

如果你的项目代码不支持可选链( optional chaining)的话,可以这样做:

  1. const found = [{ name: "Alex" }].find(i => i.name === 'Jim'); 
  2. console.log(found.name); 
  3. // TypeError: Cannot read property 'name' of undefined 

可以这样避免

  1. const found = [{ name: "Alex" }].find(i => i.name === 'Jim') || {}; 
  2. console.log(found.name); 
  3. // undefined 

不过这要视情况而定,对于小规模的代码进行处理完全没什么问题。不需要太多代码就可以处理它。

6. 传参的好方法

在 ES6 中可以把 模板字面量(Template literal) 当作是不带括号的函数的参数。这在进行格式化或转换文本的时非常好用。

  1. const makeList = (raw) => 
  2.   raw 
  3.     .join() 
  4.     .trim() 
  5.     .split("\n") 
  6.     .map((s, i) => `${i + 1}. ${s}`) 
  7.     .join("\n"); 
  8.  
  9. makeList` 
  10. Hello, World 
  11. Hello, World 
  12. `; 
  13.  
  14. // 1. Hello 
  15. // 2. World 

7. 像变戏法一样交换变量的值

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

  1. let a = "hello"
  2. let b = "world"
  3.  
  4. // 错误 ❌ 
  5. a = b 
  6. b = a 
  7. // { a: 'world', b: 'world' } 
  8.  
  9. // 正确 ✅ 
  10. [a, b] = [b, a]; 
  11. // { a: 'world', b: 'hello' } 

8. 遮蔽字符串

某些时候我们需要遮蔽字符串的一部分,当然不只是对密码做这种操作。下面代码中通过 substr(-3) 得到字符串的一部分,即从字符串末尾开始往前 3 个字符,然后再用你喜欢的字符填充剩余的位置(比如说用 *)

  1. const password = "hackme"
  2. password.substr(-3).padStart(password.length, "*"); 
  3. // ***kme 

 

来源:前端先锋内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯