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


Posted in Javascript onJanuary 29, 2017

带名函数是指函数显示地给出了一个名字的函数,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中 带名 匿名 箭头函数的重要区别,希望对大家有所帮助,如果有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
引用其它js时如何同时处理多个window.onload事件
Sep 02 Javascript
举例简介AngularJS的内部语言环境
Jun 17 Javascript
jQuery控制div实现随滚动条滚动效果
Jun 07 Javascript
JS判断输入字符串长度实例代码(汉字算两个字符,字母数字算一个)
Aug 02 Javascript
js HTML5多图片上传及预览实例解析(不含前端的文件分割)
Aug 26 Javascript
JavaScript字符集编码与解码详谈
Feb 02 Javascript
深入解析Vue 组件命名那些事
Jul 18 Javascript
vue-infinite-loading2.0 中文文档详解
Apr 08 Javascript
node错误处理与日志记录的实现
Dec 24 Javascript
ES6 Symbol在对象中的作用实例分析
Jun 06 Javascript
给原生html中添加水印遮罩层的实现示例
Apr 02 Javascript
quickjs 封装 JavaScript 沙箱详情
Nov 02 Javascript
jQuery图片轮播功能实例代码
Jan 29 #Javascript
jQuery代码实现实时获取时间
Jan 29 #Javascript
用director.js实现前端路由使用实例
Jan 27 #Javascript
详解bootstrap的modal-remote两种加载方式【强化】
Jan 27 #Javascript
Jquery uploadify 多余的Get请求(404错误)的解决方法
Jan 26 #Javascript
js监听input输入框值的实时变化实例
Jan 26 #Javascript
jquery实现input框获取焦点的简单实例
Jan 26 #Javascript
You might like
php利用header函数实现文件下载时直接提示保存
2009/11/12 PHP
php递归法读取目录及文件的方法
2015/01/30 PHP
php实现微信扫码自动登陆与注册功能
2016/09/22 PHP
php高清晰度无损图片压缩功能的实现代码
2018/12/09 PHP
jquery 表格分页等操作实现代码(pagedown,pageup)
2010/04/11 Javascript
Jquery知识点二 jquery下对数组的操作
2011/01/15 Javascript
仿新浪微博返回顶部的jquery实现代码
2012/10/01 Javascript
JS实现的简洁二级导航菜单雏形效果
2015/10/13 Javascript
javascript实现抽奖程序的简单实例
2016/06/07 Javascript
JS中递归函数
2016/06/17 Javascript
AngularJS入门教程之过滤器详解
2016/08/19 Javascript
js实现简单的手风琴效果
2017/02/27 Javascript
Angular5中提取公共组件之radio list的实例代码
2018/07/10 Javascript
解决vue中使用Axios调用接口时出现的ie数据处理问题
2018/08/13 Javascript
nodejs微信开发之授权登录+获取用户信息
2019/03/17 NodeJs
Python中使用PIPE操作Linux管道
2015/02/04 Python
python中list列表的高级函数
2016/05/17 Python
Python Socket编程详细介绍
2017/03/23 Python
python实现ID3决策树算法
2017/12/20 Python
详解python深浅拷贝区别
2019/06/24 Python
python 两个数据库postgresql对比
2019/10/21 Python
pygame实现成语填空游戏
2019/10/29 Python
python flask搭建web应用教程
2019/11/19 Python
pytorch 实现cross entropy损失函数计算方式
2020/01/02 Python
使用tensorboard可视化loss和acc的实例
2020/01/21 Python
Python如何把十进制数转换成ip地址
2020/05/25 Python
Python装饰器结合递归原理解析
2020/07/02 Python
美国潜水装备、水肺潜水和浮潜设备商店:Leisure Pro
2018/08/08 全球购物
生物技术专业毕业生求职信范文
2013/12/14 职场文书
感恩父母的演讲稿
2014/05/06 职场文书
师德师风建设整改措施思想汇报
2014/10/11 职场文书
2014年计划生育工作总结
2014/11/14 职场文书
孔繁森观后感
2015/06/10 职场文书
植树节新闻稿
2015/07/17 职场文书
村主任当选感言
2015/08/01 职场文书
Python函数中apply、map、applymap的区别
2021/11/27 Python