91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

普通函數與箭頭函數在JavaScript中的區別是什么

發布時間:2021-01-14 15:54:06 來源:億速云 閱讀:178 作者:Leah 欄目:web開發

普通函數與箭頭函數在JavaScript中的區別是什么?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

箭頭函數中的 this

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

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

這個例子可以看到,確實箭頭函數在定義之后,this 就不會發生改變了,無論用什么樣的方式調用它,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]

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

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

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

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

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

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

或者

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

然而第二種方法只能固定 this 這一個變量而已,如前文所述,箭頭函數中的 arguments 等變量也是從作用域鏈中尋找的,為了實現類似的效果,我們只有重新定義一個局部變量這一種方式,而 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中的區別是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌兰县| 自治县| 怀宁县| 台安县| 永康市| 大宁县| 贺州市| 樟树市| 嘉峪关市| 柞水县| 五莲县| 溧水县| 万盛区| 武川县| 长泰县| 怀化市| 翁牛特旗| 青神县| 普定县| 南郑县| 岑巩县| 崇州市| 大方县| 江永县| 德阳市| 新蔡县| 永嘉县| 泰兴市| 舒兰市| 建水县| 新田县| 连江县| 敦煌市| 宁津县| 临城县| 洛扎县| 梅河口市| 神木县| 安国市| 临颍县| 宜良县|