Szukaj…


to z prostymi przedmiotami

var person = {
  name: 'John Doe',
  age: 42,
  gender: 'male',
  bio: function() {
    console.log('My name is ' + this.name);
  }
};
person.bio(); // logs "My name is John Doe"
var bio = person.bio;
bio(); // logs "My name is undefined"

W powyższym kodzie person.bio korzysta z kontekstu ( this ). Gdy funkcja jest wywoływana jako person.bio() , kontekst jest przekazywany automatycznie, więc poprawnie loguje się „Nazywam się John Doe”. Jednak przypisując funkcję do zmiennej, traci swój kontekst.

W trybie ścisłym domyślnym kontekstem jest obiekt globalny ( window ). W trybie ścisłym jest undefined .

Zapisywanie tego do użycia w zagnieżdżonych funkcjach / obiektach

Częstą pułapką jest próba użycia this w zagnieżdżonej funkcji lub obiekcie, w którym kontekst został utracony.

document.getElementById('myAJAXButton').onclick = function(){
    makeAJAXRequest(function(result){
      if (result) { // success
        this.className = 'success';
      }
    })
}

Tutaj kontekst ( this ) zostaje utracony w wewnętrznej funkcji zwrotnej. Aby to poprawić, możesz zapisać wartość this w zmiennej:

document.getElementById('myAJAXButton').onclick = function(){
    var self = this;
    makeAJAXRequest(function(result){
      if (result) { // success
        self.className = 'success';
      }
    })
}
6

ES6 wprowadzono funkcje strzałek , które obejmują leksykalny this wiążące. Powyższy przykład można zapisać w następujący sposób:

document.getElementById('myAJAXButton').onclick = function(){
    makeAJAXRequest(result => {
      if (result) { // success
        this.className = 'success';
      }
    })
}

Kontekst funkcji wiązania

5.1

Każda funkcja ma metodę bind , która utworzy zapakowaną funkcję, która wywoła ją w odpowiednim kontekście. Zobacz tutaj, aby uzyskać więcej informacji.

var monitor = {
  threshold: 5,
  check: function(value) {
    if (value > this.threshold) {
      this.display("Value is too high!");
    }
  },
  display(message) {
    alert(message);
  }
};

monitor.check(7); // The value of `this` is implied by the method call syntax.


var badCheck = monitor.check;
badCheck(15); // The value of `this` is window object and this.threshold is undefined, so value > this.threshold is false

var check = monitor.check.bind(monitor);
check(15); // This value of `this` was explicitly bound, the function works.

var check8 = monitor.check.bind(monitor, 8);
check8(); // We also bound the argument to `8` here. It can't be re-specified.

Mocne wiązanie

  • Przedmiotem oprawa twarda jest „twardy” link odniesienie do this .
  • Zaleta: Przydaje się, gdy chcesz zabezpieczyć poszczególne obiekty przed zagubieniem.
  • Przykład:
function Person(){
    console.log("I'm " + this.name);
}

var person0 = {name: "Stackoverflow"}
var person1 = {name: "John"};
var person2 = {name: "Doe"};
var person3 = {name: "Ala Eddine JEBALI"};

var origin = Person;
Person = function(){
    origin.call(person0);
}

Person();
//outputs: I'm Stackoverflow

Person.call(person1);
//outputs: I'm Stackoverflow


Person.apply(person2);
//outputs: I'm Stackoverflow


Person.call(person3);
//outputs: I'm Stackoverflow
  • Tak więc, jak można zauważyć w powyższym przykładzie, bez względu na obiekt, który przekażesz osobie , zawsze użyje on obiektu person0 : jest on mocno powiązany .

w funkcjach konstruktora

Gdy funkcja jest używana jako konstruktor , ma specjalne this powiązanie, które odnosi się do nowo utworzonego obiektu:

function Cat(name) {
  this.name = name;
  this.sound = "Meow";
}

var cat = new Cat("Tom"); // is a Cat object
cat.sound; // Returns "Meow"

var cat2 = Cat("Tom"); // is undefined -- function got executed in global context
window.name; // "Tom"
cat2.name; // error! cannot access property of undefined


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow