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 相关文章推荐
JavaScript asp.net 获取当前超链接中的文本
Apr 14 Javascript
JavaScript全排列的六种算法 具体实现
Jun 29 Javascript
详解JavaScript中的异常处理方法
Jun 16 Javascript
JavaScript程序设计之JS调试
Dec 09 Javascript
浅析JavaScript中的变量复制、参数传递和作用域链
Jan 13 Javascript
jQuery 弹出层插件(推荐)
May 24 Javascript
深入理解jQuery3.0的domManip函数
Sep 01 Javascript
JavaScript中数组slice和splice的对比小结
Sep 22 Javascript
详解jQuery停止动画——stop()方法的使用
Dec 14 Javascript
AngularJS中使用three.js的实例详解
Jul 21 Javascript
微信小程序 子级页面返回父级并把子级参数带回父级实现方法
Aug 22 Javascript
Webpack中loader打包各种文件的方法实例
Sep 03 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&mysql(三)
2006/10/09 PHP
PHP 常用函数库和一些实用小技巧
2009/01/01 PHP
php+mysql大量用户登录解决方案分析
2014/12/29 PHP
CodeIgniter框架验证码类库文件与用法示例
2017/03/18 PHP
php/JS实现的生成随机密码(验证码)功能示例
2019/06/06 PHP
JScript中的undefined和"undefined"的区别
2007/03/08 Javascript
关于viewport,Ext.panel和Ext.form.panel的关系
2009/05/07 Javascript
JavaScript实现GriwView单列全选(自写代码)
2013/05/13 Javascript
顶部缓冲下拉菜单导航特效的JS代码
2013/08/27 Javascript
不使用script导入js文件的几种方法
2016/10/27 Javascript
jquery实现文字单行横移或翻转(上下、左右跳转)
2017/01/08 Javascript
JavaScript解析JSON格式数据的方法示例
2017/01/24 Javascript
JavaScript实现鼠标点击导航栏变色特效
2017/02/08 Javascript
js获取json中key所对应的value值的简单方法
2020/06/17 Javascript
jquery ui sortable拖拽后保存位置
2017/04/27 jQuery
bootstrap模态框远程示例代码分享
2017/05/22 Javascript
react高阶组件经典应用之权限控制详解
2017/09/07 Javascript
Vue DevTools调试工具的使用
2017/12/05 Javascript
JavaScript实现密码强度实时验证
2020/03/18 Javascript
解决vue自定义指令导致的内存泄漏问题
2020/08/04 Javascript
Jquery+javascript实现支付网页数字键盘
2020/12/21 jQuery
python3中获取文件当前绝对路径的两种方法
2018/04/26 Python
如何利用Boost.Python实现Python C/C++混合编程详解
2018/11/08 Python
Pycharm远程调试原理及具体配置详解
2019/08/08 Python
python生成随机红包的实例写法
2019/09/02 Python
python DataFrame转dict字典过程详解
2019/12/26 Python
python爬取音频下载的示例代码
2020/10/19 Python
澳大利亚设计的婴儿和女孩的衣服:Oobi
2018/12/16 全球购物
程序员机试试题汇总
2012/03/07 面试题
仓库门卫岗位职责
2013/12/22 职场文书
高三生物教学反思
2014/01/25 职场文书
社区好人好事材料
2014/12/26 职场文书
交通安全主题班会
2015/08/12 职场文书
2016年教师师德师风心得体会
2016/01/12 职场文书
jQuery实现广告显示和隐藏动画
2021/07/04 jQuery
Java完整实现记事本代码
2022/06/16 Java/Android