欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的普通函數和箭頭函數的區(qū)別和用法詳解

 更新時間:2017年03月21日 09:47:41   作者:不帶汽的可樂  
這篇文章主要介紹了JavaScript中的普通函數和箭頭函數的區(qū)別和用法詳解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

最近被問到了一個問題:

javaScript 中的箭頭函數 ( => ) 和普通函數 ( function ) 有什么區(qū)別?

我當時想的就是:這個問題很簡單啊~(flag),然后做出了錯誤的回答……

箭頭函數中的 this 和調用時的上下文無關,而是取決于定義時的上下文

這并不是很正確的答案……雖然也不是完全錯誤

箭頭函數中的 this

首先說我的回答中沒有錯誤的部分:箭頭函數中的 this 確實和調用時的上下文無關

function make () {
  return ()=>{
    console.log(this);
  }
}
const testFunc = make.call({ name:'foo' });
testFunc(); //=> { name:'foo' }
testFunc.call({ name:'bar' }); //=> { name:'foo' }

這個例子可以看到,確實箭頭函數在定義之后,this 就不會發(fā)生改變了,無論用什么樣的方式調用它,this 都不會改變;

但嚴格來說,這并不是“取決于定義時的上下文”, 因為箭頭函數根本就沒有綁定自己的 this,在箭頭函數中調用 this 時,僅僅是簡單的沿著作用域鏈向上尋找,找到最近的一個 this 拿來使用罷了;
從效果上看,這和我之前的理解并沒有多大偏差,但它們的本質卻是截然不同,箭頭函數并不是普通函數新增了 this 不受調用時上下文影響的特性,而是減少了很多特性;

箭頭函數其實是更簡單的函數

實際上箭頭函數中并不只是 this 和普通函數有所不同,箭頭函數中沒有任何像 this 這樣自動綁定的局部變量,包括:this,arguments,super(ES6),new.target(ES6)……

借用別人的一個例子:

function foo() {
  setTimeout( () => {
   console.log("args:", arguments);
  },100);
}
foo( 2, 4, 6, 8 );
// args: [2, 4, 6, 8]

在普通函數中,會自動綁定上的各種局部變量,箭頭函數都是十分單純的沿著作用域鏈向上尋找……

箭頭函數就是這么個簡單、純粹的東西;

所以我個人認為箭頭函數更適合函數式編程,除了它更短以外,使用箭頭函數也更難被那些沒有顯示聲明的變量影響,導致你產生意料之外的計算結果;

那么普通函數能否實現(xiàn)和箭頭函數一樣的效果呢?

如果是像當初的我一樣簡單的考慮固定住 this 這個易變的家伙……那倒是很簡單,有些常用的方法,比如這樣:

function make () {
  var self = this;
  return function () {
    console.log(self);
  }
}

或者

function make () {
  return function () {
    console.log(this);
  }.bind(this);
}

然而第二種方法只能固定 this 這一個變量而已,如前文所述,箭頭函數中的 arguments 等變量也是從作用域鏈中尋找的,為了實現(xiàn)類似的效果,我們只有重新定義一個局部變量這一種方式,而 babel 也是使用這種方式對箭頭函數進行處理的。

function make () {
  return ()=>{
    console.log(this);
    console.log(arguments);
  }
}
//babel it...
function make() {
  var _this = this,
    _arguments = arguments;
  return function () {
    console.log(_this);
    console.log(_arguments);
  };
}

那么……如果我想在箭頭函數中使用 arguments 該怎么辦?

……我覺得如果你有這個需求,可能還是用普通函數更合適一點……

但并不是說在箭頭函數中無法以類似數組的形式取到所有參數,我們可以利用展開運算符來接收參數,比如這樣:

const testFunc = (...args)=>{
  console.log(args) //數組形式輸出參數
}

或許真的有場景需要用到這種寫法,但我還是認為,箭頭函數更適合那些接受固定的參數,返回一個計算結果的簡單情況;

以上所述是小編給大家介紹的JavaScript中的普通函數和箭頭函數的區(qū)別和用法詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • JS實現(xiàn)的5級聯(lián)動Select下拉選擇框實例

    JS實現(xiàn)的5級聯(lián)動Select下拉選擇框實例

    這篇文章主要介紹了JS實現(xiàn)的5級聯(lián)動Select下拉選擇框,涉及javascript數組調用及遍歷的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • JavaScript創(chuàng)建對象的四種常用模式實例分析

    JavaScript創(chuàng)建對象的四種常用模式實例分析

    這篇文章主要介紹了JavaScript創(chuàng)建對象的四種常用模式,結合實例形式分析了javascript使用工廠模式、構造函數模式、原型模式及動態(tài)原型模式創(chuàng)建對象的相關操作技巧與注意事項,需要的朋友可以參考下
    2019-01-01
  • JavaScript 變量、作用域及內存

    JavaScript 變量、作用域及內存

    這篇文章主要介紹了JavaScript 變量、作用域及內存,需要的朋友可以參考下
    2015-04-04
  • JavaScript中使用import 和require打包后實現(xiàn)原理分析

    JavaScript中使用import 和require打包后實現(xiàn)原理分析

    這篇文章主要介紹了JavaScript中使用import 和require打包后實現(xiàn)原理分析,需要的朋友可以參考下
    2018-03-03
  • javascript實現(xiàn)支付寶滑塊驗證碼效果

    javascript實現(xiàn)支付寶滑塊驗證碼效果

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)支付寶滑塊驗證碼效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • javascript 中的console.log和彈出窗口alert

    javascript 中的console.log和彈出窗口alert

    這篇文章主要介紹了javascript 中的console.log和彈出窗口alert 的相關資料,非常不錯,具有參考借鑒價值,感興趣的朋友參考下吧
    2016-08-08
  • JavaScript獲取對象鍵名的五種方法

    JavaScript獲取對象鍵名的五種方法

    在 JavaScript 中,操作對象時獲取鍵名是高頻需求,不同場景下,我們需要篩選「自身/繼承屬性」「可枚舉/不可枚舉鍵」「字符串/Symbol 鍵」,本文將全面梳理 5 種核心方法的差異與適用場景,助你精準選擇,需要的朋友可以參考下
    2025-04-04
  • 微信小程序多列表渲染數據開關互不影響的實現(xiàn)

    微信小程序多列表渲染數據開關互不影響的實現(xiàn)

    這篇文章主要介紹了微信小程序多列表渲染數據開關互不影響的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • JavaScript復制變量三種方法實例詳解

    JavaScript復制變量三種方法實例詳解

    這篇文章主要介紹了JavaScript復制變量三種方法實例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01
  • javascript入門基礎之私有變量

    javascript入門基礎之私有變量

    開始接觸這門語言時,可能都會覺得這門語言缺少訪問控制符(如public、private、protected),從而導致不能定義私有變量和私有方法。但經過進一步了解就會知道javascript同樣可以有私有變量。
    2010-02-02

最新評論