文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript重构技巧-让函数简单明了

2024-12-24 17:32

关注

JavaScript 是一种易于学习的编程语言,编写运行并执行某些操作的程序很容易。然而,要编写一段干净的JavaScript 代码是很困难的。

在本文中,我们将研究如何让我们的函数更清晰明了。

[[327780]]

对对象参数使用解构

如果我们希望函数接收很多参数,那么应该使用对象。在此基础上,我们就可以使用解构语法提取我们需要的参数。

例如,对于对象参数,我们可能会这样使用:

  1. const greet = (obj) => { 
  2.   return `${obj.greeting}, ${obj.firstName}${obj.lastName}`; 

上面的语法,我们可以使用解构方式会更优雅:

  1. const greet = ({ 
  2.   greeting, 
  3.   firstName, 
  4.   lastName 
  5. }) => { 
  6.   return `${greeting}, ${firstName}${lastName}`; 

这样我们可以少写很多重复的东西,命名也会更加清晰。

命名回调函数

好的命名会使阅读代码更容易,回调函数的命名也是一样的,例如下面不好的命名方式:

  1. const arr = [1, 2, 3].map(a => a * 2); 

我们可以这样分开命名:

  1. const double = a => a * 2; 
    1. if (score === 100 || 
    2.   remainingPlayers === 1 || 
    3.   remainingPlayers === 0) { 
    4.   quitGame(); 
  2. const arr = [1, 2, 3].map(double); 

现在我们知道我们的回调函数实际上是用来加倍原始数组的每个元素的。

让条件句具有描述性

通过在自己的函数的条件语句中编写条件表达式,可以使条件语句更具描述性。

对于复杂的条件判断, 我们可以单独使用函数来表示,会让条件语句更具描述性,例如下面代码:

  1. if (score === 100 || 
  2.   remainingPlayers === 1 || 
  3.   remainingPlayers === 0) { 
  4.   quitGame(); 

当条件多时,我们可以用函数来表示:

  1. const winnerExists = () => { 
  2.   return score === 100 || 
  3.     remainingPlayers === 1 || 
  4.     remainingPlayers === 0 
  5. if (winnerExists()) { 
  6.   quitGame(); 

这样,我们就知道这些条件是检查游戏代码中是否存在赢家的条件。

在第一个例子中,我们有一个很长的表达式在括号里,大多数人可能不知道它在判断什么。但在第二个例子中,一旦我们把它放到一个命名函数中,我们就知道它大概在判断什么了。

在条件语句中拥有一个命名函数比在拥有一堆布尔表达式要清晰得多。

用 Map 或 Object替换 switch 语句

由于 switch语句很长,这样容易出错。因此,如果可以的话,我们应该用较短的代码代替它们。许多switch语句可以用map或object替换。例如,如果我们有下面的switch语句:

  1. const getValue = (prop) => { 
  2.   switch (prop) { 
  3.     case 'a': { 
  4.       return 1; 
  5.     } 
  6.     case 'b': { 
  7.       return 2; 
  8.     } 
  9.     case 'c': { 
  10.       return 3; 
  11.     } 
  12.   } 
  13. const val = getValue('a'); 

我们可以将其替换为object或map,如下所示:

  1. const obj = { 
  2.   a: 1, 
  3.   b: 2, 
  4.   c: 3 
  5. const val = obj['a']; 

如我们所见,switch 语法很长。我们需要嵌套多个带有多个return语句的块,只是为了获得给定prop值的返回值。

相反使用对象,我们仅仅需要一个对象就可以了:

  1. const obj = { 
  2.   a: 1, 
  3.   b: 2, 
  4.   c: 3 

使用对象还有一个好处,就是对于键不必是有效的标识符号,这样这增加了更多的灵活性。

我们还可以使用map替换对象,如下所示:

  1. const map = new Map([['a', 1], ['b', 2], ['c', 3]]) 
  2. const val = map.get('a') 

如我们所见,使用Map时,代码也短很多。我们通过传递一个数组,数组中的每项包含键和值。然后,我们仅使用Map实例的get方法从键中获取值。

Map优于对象的一个好处是,我们可以将数字,布尔值或对象等其他值用作键。而对象只能将字符串或symbol作为键。

总结

使用解构语法可以使对象参数更清楚,更短。这样,可以选择性地将属性作为变量进行访问。

通过将条件表达式放在它自己的命名函数中,可以使条件表达式更具描述性。同样,我们应该为回调函数命名,以便更容易地读取代码。

最后,应该尽可能用Map和Object替换switch语句。

 

来源:大迁世界内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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