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在页面底部加载的注意事项介绍
Jul 18 Javascript
JavaScript中圆括号()和方括号[]的特殊用法疑问解答
Aug 06 Javascript
jQuery提交多个表单的小技巧
Jul 27 Javascript
jquery插件NProgress.js制作网页加载进度条
Jun 05 Javascript
实例讲解jquery与json的结合
Jan 07 Javascript
JS动态的把左边列表添加到右边的实现代码(可上下移动)
Nov 17 Javascript
jQuery+CSS实现的table表格行列转置功能示例
Jan 08 jQuery
深入了解js原型模式
May 30 Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
Nov 06 Javascript
微信小程序实现横向滚动导航栏效果
Dec 12 Javascript
mpvue网易云短信接口实现小程序短信登录的示例代码
Apr 03 Javascript
解决vant框架做H5时踩过的坑(下拉刷新、上拉加载等)
Nov 11 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
PHP闭包函数详解
2016/02/13 PHP
Laravel 集成微信用户登录和绑定的实现
2019/12/27 PHP
ExtJs使用IFrame的实现代码
2010/03/24 Javascript
教你如何使用firebug调试功能了解javascript闭包和this
2015/03/04 Javascript
jQuery对checkbox 复选框的全选全不选反选的操作
2016/08/09 Javascript
Angular的自定义指令以及实例
2016/12/26 Javascript
使用vue.js实现联动效果的示例代码
2017/01/10 Javascript
微信小程序 自定义对话框实例详解
2017/01/20 Javascript
AngularJS 单选框及多选框的双向动态绑定
2017/04/20 Javascript
利用Vue2.x开发实现JSON树的方法
2018/01/04 Javascript
vue-resource:jsonp请求百度搜索的接口示例
2019/11/09 Javascript
[03:05]《我与DAC》之xiao8:DAC与BG
2018/03/27 DOTA
[55:16]Mski vs VGJ.S Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
[07:01]DOTA2-DPC中国联赛正赛 Aster vs Magma 3月5日 赛后选手采访
2021/03/11 DOTA
Python中声明只包含一个元素的元组数据方法
2014/08/25 Python
简单介绍Python中的len()函数的使用
2015/04/07 Python
Python3 中文文件读写方法
2018/01/23 Python
python中的随机函数random的用法示例
2018/01/27 Python
python读取文本中的坐标方法
2018/10/14 Python
对python pandas读取剪贴板内容的方法详解
2019/01/24 Python
使用python3构建文件传输的方法
2019/02/13 Python
Python3.7安装keras和TensorFlow的教程图解
2020/06/18 Python
VSCode中自动为Python文件添加头部注释
2019/11/14 Python
6行Python代码实现进度条效果(Progress、tqdm、alive-progress​​​​​​​和PySimpleGUI库)
2020/01/06 Python
python实现在内存中读写str和二进制数据代码
2020/04/24 Python
python 可视化库PyG2Plot的使用
2021/01/21 Python
css3的transform造成z-index无效解决方案
2014/12/04 HTML / CSS
HTML5对手机页面长按会粘贴复制禁用的解决方法
2016/07/19 HTML / CSS
HTML5安全介绍之内容安全策略(CSP)简介
2012/07/10 HTML / CSS
自荐信格式简述
2014/01/25 职场文书
应聘编辑自荐信范文
2014/03/12 职场文书
初中学生操行评语
2014/12/26 职场文书
会议承办单位欢迎词
2019/07/09 职场文书
浅谈JS和Nodejs中的事件驱动
2021/05/05 NodeJs
JavaScript中reduce()的用法
2022/05/11 Javascript