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 相关文章推荐
Array.prototype 的泛型应用分析
Apr 30 Javascript
10个很棒的jQuery代码片段
Sep 24 Javascript
JavaScript实现数据类型的相互转换
Mar 06 Javascript
Vue.js实战之通过监听滚动事件实现动态锚点
Apr 04 Javascript
vue-router单页面路由
Jun 17 Javascript
JavaScript定义函数_动力节点Java学院整理
Jun 27 Javascript
Vuejs 页面的区域化与组件封装的实现
Sep 11 Javascript
vue中实现图片和文件上传的示例代码
Mar 16 Javascript
vue获取元素宽、高、距离左边距离,右,上距离等还有XY坐标轴的方法
Sep 05 Javascript
Vue scoped及deep使用方法解析
Aug 01 Javascript
微信小程序获取当前时间及星期几的实例代码
Sep 20 Javascript
在antd中setFieldsValue和defaultVal的用法
Oct 29 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
用函数读出数据表内容放入二维数组
2006/10/09 PHP
截获网站title标签之家内容的例子
2006/10/09 PHP
基于MySQL分区性能的详细介绍
2013/05/02 PHP
php魔术方法与魔术变量、内置方法与内置变量的深入分析
2013/06/03 PHP
PHP迭代器的内部执行过程详解
2013/11/12 PHP
php 一维数组的循环遍历实现代码
2017/04/10 PHP
js监听表单value的修改同步问题,跨浏览器支持
2009/12/31 Javascript
jquery zTree异步加载简单实例分享
2013/02/05 Javascript
javascript实现动态标签云
2015/10/16 Javascript
AngularJS学习笔记之依赖注入详解
2016/05/16 Javascript
JS实现的表格行上下移动操作示例
2016/08/03 Javascript
thinkjs 文件上传功能实例代码
2017/11/08 Javascript
小程序实现搜索界面 小程序实现推荐搜索列表效果
2019/05/18 Javascript
微信公众号生成新浪短网址的实现(快速生成)
2019/08/18 Javascript
用原生JS实现爱奇艺首页导航栏代码实例
2019/09/19 Javascript
vue.js实现二级菜单效果
2019/10/19 Javascript
JS模拟实现京东快递单号查询
2020/11/30 Javascript
[01:23]2014DOTA2国际邀请赛 球迷无处不在Ti现场世界杯受关注
2014/07/10 DOTA
Python的面向对象思想分析
2015/01/14 Python
介绍Python中的fabs()方法的使用
2015/05/14 Python
Python中if __name__ == '__main__'作用解析
2015/06/29 Python
numpy.std() 计算矩阵标准差的方法
2018/07/11 Python
python写入文件自动换行问题的方法
2019/07/05 Python
python3 中的字符串(单引号、双引号、三引号)以及字符串与数字的运算
2019/07/18 Python
python反转列表的三种方式解析
2019/11/08 Python
python生成并处理uuid的实现方式
2020/03/03 Python
浅谈Python3多线程之间的执行顺序问题
2020/05/02 Python
协程Python 中实现多任务耗资源最小的方式
2020/10/19 Python
日本最大的购物网站乐天市场国际版:Rakuten Global Market(支持中文)
2020/02/03 全球购物
如何写出好的Java代码
2014/04/25 面试题
集体备课反思
2014/02/12 职场文书
怎样写好自我评价呢?
2014/02/16 职场文书
单方离婚协议书范本(2014版)
2014/09/30 职场文书
国防教育标语
2014/10/08 职场文书
实验心得体会范文
2016/01/25 职场文书
MySQL配置主从服务器(一主多从)
2021/08/07 MySQL