当前位置:首页 > 日记 > 正文

Javascript中 带名 匿名 箭头函数的重要区别 | 推荐

Javascript中 带名 匿名 箭头函数的重要区别 | 推荐

带名函数是指函数显示地给出了一个名字的函数,function abs(x){}。匿名函数是指函数只带有function这个关键字,而没有像abs这种函数名称的函数,如function(){}。ES6标准新增了一种新的函数:Arrow Function(箭头函数)箭头函数表面上相当于匿名函数,并且简化了函数定义。它们各自的区别是什么呢?

1 带名和匿名函数的区别

区别:匿名函数需要讲地址赋值给另一个变量let a,然后再用a来调用函数;而带名函数因为显示地给出了函数名称,所以可以直接用这个函数名称调用。

带名函数返回值是函数体内的返回值,如abs(x)函数的返回值是number变量。函数调用时,直接abs(6)调用,这个非常好理解。

function abs(x){ if(x>=0){  return x; }else{  return -x; }}

但是匿名函数呢?如下所示,函数未显示地给出一个函数名称,但是此处的abs被赋值为这个匿名函数的地址,所以使用时可以直接用abs(-3),诸如此类的调用。

let abs=function(x){  if(x>=0){  return x; }else{  return -x; }}

2 箭头函数

ES6标准新增了一种新的函数:Arrow Function(箭头函数)。为什么叫Arrow Function?因为它的定义用的就是一个箭头。箭头函数表面上相当于匿名函数,并且简化了函数定义。

箭头函数有两种格式,一种是只包含一个表达式,连{ … }和return都省略掉了。

x => x * x

上面的箭头函数相当于一个匿名函数“”

function (x) { return x * x;}

还有一种可以包含多条语句,这时候就不能省略{ … }和return:

(x,y) => { if (x > 0) {  return x + y; } else {  return -x + y; }}

3 箭头函数和匿名函数的不同

箭头函数看上去是匿名函数的一种简写,但实际上,箭头函数和匿名函数有个明显的区别:箭头函数内部的this是词法作用域,由上下文确定。

调用函数obj1.getAge(2017)和调用obj2.getAge(2017)会得到相同的结果吗?

obj1中fn函数,由于JavaScript函数对this绑定的错误处理,得不到预期的结果,this.birth指向window或undefined。

但是obj2,fn函数是箭头函数,箭头函数完全修复了this的指向,this总是指向词法作用域,也就是外层调用者obj2。

var obj1 = { birth: 1990, getAge: function (year) {   let fn=function(y){   return y - this.birth; // this指向window或undefined  };   return fn(year);  }};var obj2 = { birth: 1990, getAge: function (year) {  var fn = (y) => y - this.birth; // this.birth为1990  return fn(year); }};

4 总结

和带名函数相比,匿名函数需要讲地址赋值给另一个变量let a,然后再用a来调用函数;和匿名函数比,箭头函数完全修复了this的指向,this总是指向词法作用域。

以上所述是小编给大家介绍的Javascript中 带名 匿名 箭头函数的重要区别,希望对大家有所帮助,如果有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

Centos6.8下Node.js安装教程

Centos6.8下Node.js安装教程

安装教程,电脑软件,Node,js,思路:采用编译好的文件进行安装一 使用 wget 下载到 Node.js 官网(https://nodejs.org/en/download/) 选择要下载的编译版本(Source Code),复制链接cd /usr/local/src // 安装路径wget https://nodejs.org/dist/v6.10.…

ppt2010控件无法激活怎么解决图文

ppt2010控件无法激活怎么解决图文

激活,控件,解决方法,图文教程,常用快捷键,  我们在使用PPT文件的时候,可能会遇到如下问题:在自己制作PPT文件的电脑中能正常播放插入的Flash,但是弹出控件无法激活怎么办?下面小编马上就告诉大家解决控件无法激活的方法。ppt2010控件无法激…

详解Vue.js 2.0 如何使用axios

详解Vue.js 2.0 如何使用axios

如何使用,详解,电脑软件,Vue,axios,Vue.js 1.0 我们常使用 vue-resource (官方ajax库), Vue 2.0 发布后作者宣告不再对 vue-resource 进行更新, 推荐我们使用 axios (基于 Promise 的 HTTP 请求客户端,可同时在浏览器和 node.js 中使用)安装 …

详解vue2 $watch要注意的问题

详解vue2 $watch要注意的问题

要注意,详解,电脑软件,watch,使用$watch监听的时候,监听的数据是一个对象的时候,要注意几点:监听组件内某个对象里面的某项属性时,不要监听对象,直接监听对象里面的属性(深度监听),只有直接监听这个对象里面的属性,只更新对象里面的属性时也能直接监…

Photoshop 绘制蓝色水晶网页按钮

Photoshop 绘制蓝色水晶网页按钮

绘制,网页,按钮,水晶,蓝色,1.创建背景 首先,我们必须新建ps文档.大小为200*200像素. 使用圆角矩形工具创建类似形状: 在新图层上更改样式如下: 使用椭圆选框工具选出如下形状: 现在选择你的第一个图层,运行 选择>载入选区,按确定键.然…

php7安装mongoDB扩展的方法分析

php7安装mongoDB扩展的方法分析

扩展,方法,安装,电脑软件,mongoDB,本文讲述了php7安装monDB扩展的方法。分享给大家供大家参考,具体如下:这里我们使用pecl命令来安装首先来到php7的安装目录$ /usr/local/php7/bin/pecl install mondb回车,执行成功后,会输出以下结果:……Build …

jQuery实现表格奇偶行显示不同背景

jQuery实现表格奇偶行显示不同背景

奇偶,背景色,显示,表格,简单,做表格的时候,经常要让奇偶行显示不同背景色,一来使表格显得更美观,二来使同行数据查找更快捷方便。通常我们是怎么实现的呢?就是在每个tr标签上加css样式。代码如下所示:<html><style type="text/css">.odd { bac…

PS怎么制作一个晚安表情包?

PS怎么制作一个晚安表情包?

表情,电脑软件,PS,晚安表情包适合在晚上使用,这样的一个表情包能够很好的传递人与人之间的这种亲切性。要制作这样的一个表情包并不难,睡觉表情与月亮元素是非常动感的。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新…

PPT如何设置缩放比例图文教程

PPT如何设置缩放比例图文教程

缩放比例,图文教程,设置,方法,如何设置,  PPT中插入了图片,在播放时候,怎样才能引起观众的注意呢?方法很多,我们今天就介绍一种,通过放大和缩小照片,吸引观众的目光!下面小编马上就告诉大家PPT设置图片缩放比例的方法。在PPT设置图片缩放比例…

JavaScript实现网页头部进度条刷新

JavaScript实现网页头部进度条刷新

网页,刷新,进度条,电脑软件,JavaScript,本文刷新会头部会出现,因为并没有真正的参与到浏览器加载是否完整这个渲染过程中来,所以只是一个表象,并不是说这个显示完了就浏览器也加载完了所以资源。效果图:先看下html:就两个标签<div id="barbg"…

微信小程序 页面跳转传值实现代码

微信小程序 页面跳转传值实现代码

传值,页面跳转,代码,程序,电脑软件,微信小程序 页面跳转传值实现代码微信小程序的页面路径只能是五层;现在场景如下:index(首页)打开新页面 list(列表)打开新页面search(条件查询)确定条件返回 list(列表);这里有个限制,微信只能打开五层网页,意味着:在se…

PS怎么使用计数工具? PS计数工具计

PS怎么使用计数工具? PS计数工具计

工具,方法,电脑软件,PS,ps中的工具很多,今天我们就来看看计数工具的使用方法,很简单,详细如下文所示。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、举个简单的例子演示下操作方法,现在,要统计下图中的…