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 left,right,mid函数
Jun 10 Javascript
jquery uaMatch源代码
Feb 14 Javascript
javascript改变position值实现菜单滚动至顶部后固定
Jan 18 Javascript
js 用CreateElement动态创建标签示例
Nov 20 Javascript
js过滤特殊字符输入适合输入、粘贴、拖拽多种情况
Mar 22 Javascript
jquery单选框radio绑定click事件实现方法
Jan 14 Javascript
javascript常见数据验证插件大全
Aug 03 Javascript
input点击后placeholder中的提示消息消失
Jan 15 Javascript
layui.js实现的表单验证功能示例
Nov 15 Javascript
VueJS 组件参数名命名与组件属性转化问题
Dec 03 Javascript
js删除数组中某几项的方法总结
Jan 16 Javascript
JS图片懒加载的优点及实现原理
Jan 10 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
基于mysql的论坛(6)
2006/10/09 PHP
搜索和替换文件或目录的一个好类--很实用
2006/10/09 PHP
php框架Phpbean说明
2008/01/10 PHP
php 将bmp图片转为jpg等其他任意格式的图片
2009/06/21 PHP
ThinkPHP模板Switch标签用法示例
2014/06/30 PHP
JavaScript高级程序设计阅读笔记(五) ECMAScript中的运算符(一)
2012/02/27 Javascript
IFrame跨域高度自适应实现代码
2012/08/16 Javascript
JQuery中使用ajax传输超大数据的解决方法
2014/07/14 Javascript
JavaScript实现的in_array函数
2014/08/27 Javascript
用jquery实现动画跳到顶部和底部(这个比较简单)
2014/09/01 Javascript
javascript制作2048游戏
2015/03/30 Javascript
Web前端新人笔记之jquery入门心得(新手必看)
2016/05/17 Javascript
JS从一组数据中找到指定的单条数据的方法
2016/06/02 Javascript
前端弹出对话框 js实现ajax交互
2016/09/09 Javascript
如何利用JQuery实现从底部回到顶部的功能
2016/12/27 Javascript
js实现倒计时关键代码
2017/05/05 Javascript
BootStrap模态框不垂直居中的解决方法
2017/10/19 Javascript
微信小程序实现自上而下字幕滚动
2018/07/14 Javascript
Vue+axios实现统一接口管理的方法
2018/07/23 Javascript
vue-cli3全面配置详解
2018/11/14 Javascript
使用post方法实现json往返传输数据的方法
2019/03/30 Javascript
微信小程序如何调用新闻接口实现列表循环
2019/07/02 Javascript
浅析Python 3 字符串中的 STR 和 Bytes 有什么区别
2018/10/14 Python
用Python实现数据的透视表的方法
2018/11/16 Python
使用pandas 将DataFrame转化成dict
2019/12/10 Python
python中Mako库实例用法
2020/12/31 Python
css3中transition属性详解
2014/09/02 HTML / CSS
文明礼貌演讲稿
2014/05/12 职场文书
青春飞扬演讲稿
2014/09/11 职场文书
贷款担保书
2015/01/20 职场文书
建筑安全员岗位职责
2015/02/15 职场文书
辞职信模板(中英文版)
2015/02/27 职场文书
2015年采购员工作总结
2015/04/27 职场文书
重阳节主题班会
2015/08/17 职场文书
高中政治教学反思
2016/02/23 职场文书