Heim  >  Artikel  >  Web-Frontend  >  Analyse von Pfeilfunktionen in ES6 (mit Beispielen)

Analyse von Pfeilfunktionen in ES6 (mit Beispielen)

不言
不言nach vorne
2018-11-14 15:24:402359Durchsuche

Der Inhalt dieses Artikels befasst sich mit der Analyse von Pfeilfunktionen in ES6 (mit Beispielen). Freunde in Not können sich darauf beziehen.

Übersicht

Die Pfeilfunktion hat zwei Funktionen:

  1. Kürzere Schreibweise

  2. Nicht gebunden Definieren Sie dies

Grammatiktabelle

()=>{}
()=>{console.log('arrow');return null}
()=>'hello'
(num1, num2)=>num1+num2
num=>++num
()=>({name:'arrow'})

Schreibmethode

Formal

let add = (num1, num2)=>{
   return num1 + num2
}
add(1, 2)

deklariert eine Add-Variable, die eine Additionsfunktion ist, Die Funktion hat zwei formale Parameter: num1, num2, und der Rückgabewert ist das Ergebnis der Addition dieser beiden Parameter

Einzelner Parameter

let  increment = num=>{
    return num + 1
}

Oben wird eine Inkrementvariable deklariert, die die Variable ist eine automatische Inkrementierungsfunktion. Der Parameter hat nur eine formale Parameternummer und der Rückgabewert ist der Parameter, der um 1 erhöht wird. Da es nur einen Parameter gibt, ()

Kein Parameter

in Die Parameterliste der Pfeilfunktion kann weggelassen werden. Oben ist eine Variable angegeben, die den aktuellen Zeitstempel erhalten kann. Die Parameterliste kann jedoch nicht leer bleiben In diesem Fall weggelassen, sonst kommt es zu einem Syntaxfehler

Einzelner Rückgabewert

let now = () => {
    return Date.now()
}
let now==>{} // Uncaught SyntaxError: Unexpected token ==
Die obige Funktion kann auch wie folgt abgekürzt werden, da der Funktionskörper nur einen Satz hat, also

und {}return

Einzelne Rückgabe kann weggelassen werden. Wert: Objektliteral zurückgeben

Obwohl Pfeilfunktionen {} weglassen und zurückgeben können, sollten Sie bei der Rückgabe eines Objektliterals besonders darauf achten, ob es geschrieben ist wie folgt, obwohl bei der Syntaxprüfung kein Fehler gemeldet wird, aber möglicherweise nicht das, was Sie erwarten. Hier lauten die Daten, die Sie abrufen möchten, aber das Ergebnis ist undefiniert.

let now = () =>  Date.now()
Warum? Verwenden Sie babel, um

Analyse von Pfeilfunktionen in ES6 (mit Beispielen)

zu analysieren, und Sie werden feststellen, dass es in

let data=()=>{name:'hello'} // 不会报错 
console.log(data()) // undefined
ohne

analysiert wird. Vergleichen Sie das Beispiel von return4

Analyse von Pfeilfunktionen in ES6 (mit Beispielen)

In der Tat wird {name:'hello'} in den Funktionskörper geparst, {} ist das {} der Funktion, nicht das {} des Objekts, und name:'hello' wird zu einer Anweisung. Diese Art von Anweisung wird nicht häufig verwendet, erfüllt aber die js-Syntax. Beispiel:

var data = function data() {
  name: 'hello';
};
Wenn die Pfeilfunktion erforderlich ist Um ein einzelnes Objektliteral zurückzugeben, müssen Sie das Paar hinzufügen

()

var str = "";

loop1:
for (var i = 0; i Bindet dies nicht<h3></h3>Sehen Sie sich die folgende Situation an<p></p><pre class="brush:php;toolbar:false">let data=()=>({name:'hello'})
Normalerweise hoffen wir auf Zugriff Personenvariablen, wie z. B. Alter, in der Rückruffunktion von setInterval, aber jede neu definierte Funktion hat ihr eigenes This, also ist dies hier GrowUp's This, nicht Person's This, was dazu führt, dass This.age undefiniert ist Bei diesem Problem verwenden wir normalerweise eine Kompromisslösung:

function Person() {
  this.age = 0;

  setInterval(function growUp() {
    console.log(this.age)
  }, 1000);
}

var p = new Person();
Verwenden Sie eine temporäre Variable, um dies zu speichern, und vermeiden Sie die Verwendung von GrowUp. Zu diesem Zeitpunkt ist die Pfeilfunktion an der Reihe:

function Person() {
  this.age = 0;
  var that=this
  setInterval(function growUp() {
    console.log(that.age)
  }, 1000);
}

var p = new Person();
Im Pfeilfunktion, dies wird nicht gebunden sein, das heißt, er hat nicht sein eigenes Dies, also ist sein Dies zu diesem Zeitpunkt das Dies der Person. Dies ist die sogenannte Pfeilfunktion, die dies nicht bindet, und meiner Meinung nach ist die Rückruffunktion das beste Ziel für die Pfeilfunktion.

Das Ergebnis nach der Babel-Analyse ist eigentlich die alte Methode:

function Person() {
  this.age = 0;
  setInterval(()=> {
    console.log(this.age)
  }, 1000);
}

var p = new Person();
Hinweis

Die Pfeilfunktion unterstützt Standardparameter

"use strict";

function Person() {
  var _this = this;

  this.age = 0;
  setInterval(function () {
    console.log(_this.age);
  }, 1000);
}

var p = new Person();
Die Pfeilfunktion unterstützt die übrigen Parameter

let add = (num1 = 0, num2) => num1 + num2
Pfeilfunktionen unterstützen die Dekonstruktion von Parameterlisten

let add = (...numList) => numList.reduce((n1, n2) => n1 + n2)
Pfeilfunktionen unterstützen keine Argumente, es wird empfohlen, die restlichen Parameter wie oben zu schreiben

let f = ([a, b] = [1, 2], {x: c} = {x: a + b}) => a + b + c;
Objekt .defineProperty() führt zu unerwarteten Fehlern. Auswirkungen

// 栗子1
var arguments = [1, 2, 3];
var arr = () => arguments[0];

arr(); // 1
// 栗子2
function foo(n) {
  var f = () => arguments[0] + n; // 隐式绑定 foo 函数的 arguments 对象. arguments[0] 是 n
  return f();
}

foo(1); // 2
// 栗子3
function foo() { 
  var f = (...args) => args[0]; 
  return f(2); 
}

foo(1); 
// 2
Kann nicht mit neuen verwendet werden

'use strict';
var obj = {
  a: 10
};

Object.defineProperty(obj, "b", {
  get: () => {
    console.log(this.a, typeof this.a, this);
    return this.a+10; 
   // 代表全局对象 'Window', 因此 'this.a' 返回 'undefined'
  }
});
Kein Prototyp

var Foo = () => {};
var foo = new Foo(); // TypeError: Foo is not a constructor
Parse-Reihenfolge hat Auswirkungen

var Foo = () => {};
console.log(Foo.prototype); // undefined

Das obige ist der detaillierte Inhalt vonAnalyse von Pfeilfunktionen in ES6 (mit Beispielen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen