下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

编程语言编写高质量箭头函数

作者:前端小智     来源: 今日头条点击数:803发布时间: 2020-02-15 23:19:56

标签: 编程语言JavaJavascript

大神带你学编程,欢迎选课

编写高质量箭头函数的5个优秀做法。编程语言(programming language)是一种被标准化的交流技巧,用来向计算机发出指令,定义计算机程序,让程序员能够准确地定义计算机所需要使用的数据,并精确地定义在不同情况下所应当采取的行动的一种计算机语言。

 编程语言可以分成机器语言、汇编语言、高级语言三大类。计算机领域已发明了上千不同的编程语言,而且每年仍有新的编程语言诞生。

箭头功能值得流行。它的语法简洁明了,使用词法绑定绑定 this,它非常适合作为回调。在本文中,通过了解决学习5个优秀实践,以便我们可以从中学习更多箭头函数的知识,并从它身上获得更多的好处。

编程语言编写高质量箭头函数_编程语言_Java_Javascript_课课家

1. 箭头函数名推断

JS 中的箭头函数是匿名(anonymous)的:函数的name属性是''。

  1. (number=>number+1).name;//=>'' 

在调试会话或调用堆栈分析期间,匿名函数被标记为anonymous。不幸的是,anonymous程序不提供有关正在执行的代码的任何线索。

这里是执行匿名函数的代码的调试会话:

右边的调用堆栈由两个标记为anonymous的函数组成,我们无法从这样的调用堆栈信息中获得任何有用的信息。

幸运的是,函数名推断(ES2015的功能)可以在某些条件下检测到函数名称。名称推断的思想是JS 可以从其语法位置确定箭头函数名称:从保存函数对象的变量名称中获取。

我们来看看函数名称推断的工作原理:

  1. constincreaseNumber=number=>number+1;increaseNumber.name;//=>'increaseNumber' 

因为变量increaseNumber保存了箭头函数,所以 JS 决定使用increaseNumber作为该函数的名称。因此,箭头函数的名称为 'increaseNumber'。

第1个实践:

一个好的做法是使用函数名称推断来命名箭头函数。

现在我们用使用名称推断的代码检查一个调试会话:

因为箭头函数有名称,所以调用堆栈提供了有关正在执行的代码的更多信息。

  • handleButtonClick函数名称表示发生了单击事件
  • gainCounter增加一个计数器变量。

2.尽可能使用内联方式

内联函数是仅具有一个表达式的函数。我喜欢箭头功能,可以编写短内联函数。

例如,不要使用箭头函数的长形式:

  1. constarray=[1,2,3];array.map((number)=>{returnnumber*2;}); 

当箭头函数只有一个表达式时,可以轻松地删除大括号{}和return语句:

  1. constarray=[1,2,3];array.map(number=>number*2); 

第2个实践:

当函数只有一个表达式时,一个好的做法是使用内联箭头函数格式

3.胖箭头和比较运算符

比较操作符>、<、<=和>=看起来类似于f胖箭头=>(它定义了箭头函数)。当在内联箭头函数中使用这些比较操作符时,会产生一些混淆。

例如我们定义一个使用<=操作符的箭头函数

  1. constnegativeToZero=number=>number<=0?0:number; 

同一行上的两个符号=>和<=的存在会引起误解。

为了清楚地将胖箭头与比较操作符区分开,我们可以使用圆括号:

  1. constnegativeToZero=number=>(number<=0?0:number); 

第二个选项是使用更长的形式来定义箭头函数:

  1. constnegativeToZero=number=>{returnnumber<=0?0:number;}; 

这些重构消除了胖箭头符号和比较操作符之间的混淆。

第3个实践:

如果箭头函数包含操作符>、<、<=和>=,一个好的做法是将表达式包装成一对括号,或者故意使用更长的箭头函数形式。

4.构造普通对象

在内联箭头函数中使用对象字面量会触发语法错误:

  1. constarray=[1,2,3];//throwsSyntaxError!array.map(number=>{'number':number}); 

JS 认为花括号是代码块,而不是对象文字。

将对象字面量加上一对括号即可解决此问题:

  1. constarray=[1,2,3];//Works!array.map(number=>({'number':number})); 

如果对象字面量有很多属性,我们可以使用换行,同时仍然保持箭头函数内联

  1. constarray=[1,2,3];//Works!array.map(number=>({'number':number'propA':'valueA','propB':'valueB'})); 

第4个实践:

在内联箭头函数中使用对象时,把改对象包装在一对括号中。

5.注意过多的嵌套

箭头函数的语法很短,很好。但是,副作用是,当许多箭头函数嵌套时,它可能是晦涩难懂。

我们考虑以下情况。单击按钮后,启动对服务器的请求,响应准备就绪后,将各项记录到控制台:

  1. myButton.addEventListener('click',()=>{fetch('/items.json').then(response=>response.json());.then(json=>{json.forEach(item=>{console.log(item.name);});});}); 

这里有三层箭头函数的嵌套,需要花时间和精力来了解代码的作用。

为了提高嵌套函数的可读性,第一种方法是引入每个包含箭头函数的变量,该变量应简明地描述函数的功能。

  1. constreadItemsJson=json=>{json.forEach(item=>console.log(item.name));};consthandleButtonClick=()=>{fetch('/items.json').then(response=>response.json());.then(readItemsJson);};myButton.addEventListener('click',handleButtonClick); 

重构将箭头函数提取到变量readItemsJson和handleButtonClick中。嵌套级别从3减少到2。现在,我们可以更轻松地了解脚本的功能。

更好的是,可以使用async/await语法重构整个函数,这是解决函数嵌套的一个很好的方法:

  1. consthandleButtonClick=async()=>{constresponse=awaitfetch('/items.json');constjson=awaitresponse.json();json.forEach(item=>console.log(item.name));};myButton.addEventListener('click',handleButtonClick); 

第5个实践:

避免箭头函数过多的嵌套,好的做法是通过将箭头函数提取为独立函数,或者尽可能使用async/await语法。

6. 总结

JS中的箭头函数是匿名的。为了使调试更高效,一个好的实践是使用变量来保存箭头函数,这允许JS 推断函数名。

当函数主体具有一个表达式时,嵌入式箭头函数非常方便。

操作符>、<、<=和>=看起来类似于胖箭头=>,在内联箭头函数中使用这些操作符时必须小心。

对象字面量语法{prop:'value'}与代码块{}相似。因此,当将对象字面量放置在嵌入式箭头函数中时,需要将其包装在一对括号中:()=>({prop:'value'})。

最后,函数的过度嵌套模糊了代码意图。减少箭头函数嵌套的一个好方法是将它们提取到变量中。或者,尝试使用更好的特性,如async/await语法。

编程语言往往使程序员能够比使用机器语言更准确地表达他们所想表达的目的。对那些从事计算机科学的人来说,懂得程序设计语言是十分重要的,因为在当今所有的计算都需要程序设计语言才能完成。

赞(8)
踩(0)
分享到:
华为认证网络工程师 HCIE直播课视频教程