亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

ES6箭頭函數

標簽:
JavaScript

定义

ES6 允许使用“箭头”(=>)定义函数。

function handle(name){    return name;
}

等同于let handle = name => name;

关于普通函数应该知道的

  • js中的this是执行上下文,在普通函数中,this指向它的直接调用者;

  • 在默认情况下(非严格模式,即没有使用'use strict;'),在全局环境下,js中的this指向window;

约定俗成,在全局环境下,js中的this指向window

https://img1.sycdn.imooc.com//5d5dfd200001c17c08230220.png

全局环境this指向window


  • 在严格模式下,没有直接调用者的函数中的this是undefined;

如果使用“严格模式”,‘use strict’禁止this关键字指向全局对象,此时this为undefined

https://img1.sycdn.imooc.com//5d5dfd220001564f05990214.png

严格模式下this为undefined


  • 可以使用call,apply,bind函数绑定,此时this指向的是绑定的对象;

与普通函数之间的区别

1、函数体内的this对象,是定义时所在的对象,而不是使用时所在的对象;

简单而言,即箭头函数使用时,不绑定this对象,箭头函数没有自己的this,它的this是继承而来的,默认指向在定义箭头函数时所处的对象(宿主对象)。由于箭头函数没有自己的this,它所使用的this是外层代码块的this, 所以箭头函数可以方便地让我们在 setTimeout ,setInterval中方便的使用this。

不绑定this示例:

function handle () {  let obj = {    name:'andy',    age:18,    speakEnglish:function () {      console.log(this); //obj对象
      return 'YES,I CAN';
    },    talkToSomeBody:()=>{      console.log(this);  //window对象
      return 'NO';
    }
  };  console.log(obj.speakEnglish());  console.log(obj.talkToSomeBody());
}

handle();

https://img1.sycdn.imooc.com//5d5dfd270001398106730447.png

运行结果


从运行结果中可以看出,普通函数的this是现在使用的对象,而箭头函数的this是之前定义的对象,所以箭头函数可以在会改变this指向的地方代替普通函数,比如各种callback回调函数;

2、不能当做构造函数,即不能使用new命令

this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。

3、不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替
function foo() {
  setTimeout(() => {    console.log('args:', arguments);
  }, 100);
}

foo(2, 4, 6, 8)// args: [2, 4, 6, 8]

箭头函数内部的变量arguments,其实是函数foo的arguments变量。

另外,由于箭头函数没有自己的this,所以当然也就不能用call()、apply()、bind()这些方法去改变this的指向。

4、不可以使用yield命令,因此箭头函数不能用作 Generator 函数



作者:夏知更
链接:https://www.jianshu.com/p/f96ae78fe985

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消