ES5函数与ES6箭头函数比较(javascript基础)

1,ES5函数

例 function test() {},函数分为四个部分:

第一部分,保留字function;

第二部分,函数名,可以省略(function(){}..这是一个匿名函数anonymous);

第三部分,一对圆括号,中间为参数,可为空,附带两个隐藏参数,this和arguments;

第四部分,执行的代码块;

这部分只有一对括号,作用却很大。比如调用一个函数:var ss = aa; 和 var ss = aa(); 是不一样的。前面的是把函数的指针赋给了ss,ss也就是这个函数,后面的是把aa函数执行的结果赋给了ss  , ss是它的返回值。

第五部分,最后还可以加一对圆括号,为调用函数。


2,ES6箭头函数

例 () => {},函数仅保留两个部分:

第一部分,一对圆括号,传参;

第二部分,执行的代码块。

第三部分,最后还可以加一对圆括号,为调用函数。


以上,仅为结构的简单差别,用法上要做中注意的是this的指向问题:

ES5中,this指向函数执行时的上下文环境对象,this的指向有三种情况:

1,如下,b()是C对象以属性的形式调用的,c.b(),此时 b 函数中的this指向的是this.c这个对象;

注意:此种调用方式经常会出现this绑定丢失的情况,比如函数作为参数传递的时候(存在隐式赋值,这时候虽然形式上是obj.fn,实际上等于var a = obj.fn,与直接调用fn是一样的,另比如settimeout等js内置函数,也是一样)

隐式绑定

2,普通函数的调用,b(),此时this指向window;

默认绑定。

3,c.b().call({ name: "B"}),call会使this指向改变。

显式绑定

以此原理,衍生出了硬绑定:用一个函数包含对象c和函数b(),内部调用b.call(c),重复使用外部函数,实现b的this绑定。

es5提供了api,b.bind(c)


4,第四种是new操作符创建新对象的四个步骤中,会修改this指向:

1),创建一个新对象

2),原型继承

3),绑定this

4),return,如无return值,返回本身


以上四中优先级:

new > 显式 > 隐式 > 默认


console打印结果为a+

ES6中,箭头函数this的指向,是定义时,this的指向对象。此处指向factory构造函数的实例。

console打印结果为a

以上,欢迎大家借鉴与指正!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    呼呼哥阅读 3,710评论 0 1
  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    陈老板_阅读 518评论 0 1
  • 函数和对象 1、函数 1.1 函数概述 函数对于任何一门语言来说都是核心的概念。通过函数可以封装任意多条语句,而且...
    道无虚阅读 4,961评论 0 5
  • 函数参数的默认值 基本用法 ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数lo...
    oWSQo阅读 295评论 0 0
  • 亲子日记(47) 2017年11月4日 周六 晴 这周最重大的事情就是宝贝的生日了。今年的生日赶在了...
    大荔小太阳阅读 270评论 0 0

友情链接更多精彩内容