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 相关文章推荐
HTML IMG标签 onload 内存溢出导致浏览器CPU占用过高
Mar 09 Javascript
javascript下string.format函数补充
Aug 24 Javascript
javascript中文本框中输入法切换的问题
Dec 10 Javascript
js简单实现竖向tab选项卡的方法
May 04 Javascript
javascript实现网页背景烟花效果的方法
Aug 06 Javascript
JS原型链 详解及示例代码
Sep 06 Javascript
Bootstrap基本插件学习笔记之标签切换(17)
Dec 08 Javascript
在百度搜索结果中去除掉一些网站的资料(通过js控制不让显示)
May 02 Javascript
js,jq,css多方面实现简易下拉菜单功能
May 13 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
Jun 26 Javascript
基于input框覆盖掉数字英文的实例讲解
Jul 21 Javascript
详解关于Vuex的action传入多个参数的问题
Feb 22 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
火车头采集器3.0采集图文教程
2007/03/17 PHP
10个简化PHP开发的工具
2014/12/25 PHP
PHP验证码类ValidateCode解析
2017/01/07 PHP
在Laravel 的 Blade 模版中实现定义变量
2019/10/14 PHP
js 获取子节点函数 (兼容FF与IE)
2010/04/18 Javascript
javascript smipleChart 简单图标类
2011/01/12 Javascript
ie6下png图片背景不透明的解决办法使用js实现
2013/01/11 Javascript
jquery.post用法之type设置问题
2014/02/24 Javascript
Js使用WScript.Shell对象执行.bat文件和cmd命令
2014/12/18 Javascript
JavaScript获取网页支持表单字符集的方法
2015/04/02 Javascript
微信小程序 页面跳转传参详解
2016/10/28 Javascript
Angular的模块化(代码分享)
2016/12/26 Javascript
bootstrap中的 form表单属性role="form"的作用详解
2017/01/20 Javascript
微信小程序学习笔记之本地数据缓存功能详解
2019/03/29 Javascript
一篇文章带你使用Typescript封装一个Vue组件(简单易懂)
2020/06/05 Javascript
Python版微信红包分配算法
2015/05/04 Python
python线程中同步锁详解
2018/04/27 Python
Python 2.7中文显示与处理方法
2018/07/16 Python
Python2 Selenium元素定位的实现(8种)
2019/02/25 Python
pytorch实现对输入超过三通道的数据进行训练
2020/01/15 Python
python 3.8.3 安装配置图文教程
2020/05/21 Python
LocalStorage记住用户和密码功能
2017/07/24 HTML / CSS
canvas里面如何基于随机点绘制一个多边形的方法
2018/06/13 HTML / CSS
Lancome兰蔻官方旗舰店:来自法国的世界知名美妆品牌
2018/06/14 全球购物
美国职棒大联盟的官方手套、球和头盔:Rawlings
2020/02/15 全球购物
家长给孩子的表扬信
2014/01/17 职场文书
三年级科学教学反思
2014/01/29 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
2014年营业员工作总结
2014/11/18 职场文书
2014年药房工作总结
2014/11/22 职场文书
学生党员检讨书范文
2014/12/27 职场文书
社区植树节活动总结
2015/02/06 职场文书
2016年大学生暑期社会实践方案
2015/11/26 职场文书
Windows安装Anaconda3的方法及使用过程详解
2021/06/11 Python
新手入门Mysql--sql执行过程
2021/06/20 MySQL
VS2019连接MySQL数据库的过程及常见问题总结
2021/11/27 MySQL