ホームページ >ウェブフロントエンド >フロントエンドQ&A >es5 関数と es6 アロー関数の違いは何ですか?

es5 関数と es6 アロー関数の違いは何ですか?

青灯夜游
青灯夜游オリジナル
2022-10-20 17:24:421610ブラウズ

違い: 1. 記述方法が異なります。ES6 のアロー関数は「() => {}」、ES5 の関数は「function funName(){}」です; 2. let バインディングが異なります. 関数が 1 つだけの場合 パラメータを取得する場合、アロー関数は括弧を省略できます 関数が値のみを返す場合、アロー関数は中括弧を省略できます 3. これは異なるポイントを指します。es5 関数は、アロー関数は関数が呼び出されるオブジェクトを指しますが、アロー関数は定義時に this のポイント、つまりグローバル ウィンドウ オブジェクトを指します。

es5 関数と es6 アロー関数の違いは何ですか?

このチュートリアルの動作環境: Windows 7 システム、ECMAScript バージョン 6、Dell G3 コンピューター。

es6 アロー関数

アロー関数は、es6 の関数の新しい表現です。機能のシンプルさを極限まで追求!まず、最も単純なアロー関数を見てみましょう。

let fn = a => a
var m = prompt()
alert(fn(m))

es5 関数と es6 アロー関数の違いは何ですか?

アロー関数を初めて使用する人は、その簡潔な構文に驚くかもしれません。 es5

let fn=function(a){
    return a;
}
var m = prompt()
alert(fn(m))

es5 関数と es6 アロー関数の違い

ES3 と ES5 の通常の関数:## の構文と比較してみましょう。 # function a(){}

ES6 arrow function:

() => {};

たとえば、map メソッドを使用して、元の配列「マッピング」を対応する新しい配列に変換します:

//ES3,ES5写法
var a = [1,2,3,4,5];
var b = a.map(function(i) {
  return i + 1
});
 console.log(a,b);

コンソール結果

##

//ES6写法
let a = [1,2,3,4,5];
let b = a.map(i => i + 1)
console.log(a,b);
es5 関数と es6 アロー関数の違いは何ですか?コンソール結果:

es5 関数と es6 アロー関数の違いは何ですか?概要: アロー関数と通常の関数は let にバインドされています。関数のパラメーターが 1 つだけの場合は括弧を省略でき、関数が値のみを返す場合は中括弧を省略できます

それから〜ここで、このポインティング問題のアロー関数についてもお話したいと思います。

注: this が指す通常の関数: 関数が呼び出されるオブジェクト、アロー関数: 定義時の this のポイント (グローバル ウィンドウ オブジェクトを指す)

別の例:

//ES3,ES5
function foo(){
   this.a = 'a';
   this.b = 'b';
   this.c = {
      a: 'a+',
      b: function() {
        return this.a
      }
   }
}
console.log(new foo().c.b());

//ES6
function foo2(){
  this.a = 'a';
  this.b = 'b'; 
  this.c = {
    a:'a+',
    b:() => {
      return this.a
    }
  }
}
console.log(new foo2().c.b());

コンソール効果:

es5 関数と es6 アロー関数の違いは何ですか?ここでは、foo オブジェクトをインスタンス化した後、c オブジェクトの b メソッドが呼び出されていることがわかります。通常の関数では、これは関数が呼び出されるオブジェクト (c オブジェクト) を指すため、a が出力されます。 ES6のアロー関数では、関数本体のthis.aはコンストラクタfooで定義されたthis.aなのでaが出力されます。

【関連する推奨事項:

JavaScript ビデオ チュートリアル

プログラミング ビデオ

以上がes5 関数と es6 アロー関数の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。