Bind, işlevin this
içinin geçirilen parametre olmasını zorlayacak yeni bir işlev oluştururbind()
.
Aşağıda bind
, doğru olan bir üye yöntemini iletmek için nasıl kullanılacağını gösteren bir örnek verilmiştir this
:
var myButton = {
content: 'OK',
click() {
console.log(this.content + ' clicked');
}
};
myButton.click();
var looseClick = myButton.click;
looseClick(); // not bound, 'this' is not myButton - it is the globalThis
var boundClick = myButton.click.bind(myButton);
boundClick(); // bound, 'this' is myButton
Hangi çıktılar:
OK clicked
undefined clicked
OK clicked
Ayrıca 1st ( this
) parametresinden sonra fazladan parametreler ekleyebilirsiniz ve bind
bu değerleri orijinal işleve geçirir. Daha sonra ilişkili işleve ilettiğiniz ek parametreler, bağlı parametrelerden sonra iletilir:
// Example showing binding some parameters
var sum = function(a, b) {
return a + b;
};
var add5 = sum.bind(null, 5);
console.log(add5(10));
Hangi çıktılar:
15
Daha fazla bilgi ve etkileşimli örnekler için JavaScript İşlev bağına göz atın .
Güncelleme: ECMAScript 2015 =>
işlevler için destek ekler . =>
işlevleri daha kompakttır ve this
işaretçiyi tanımlayıcı kapsamından değiştirmez, bu nedenle bind()
sık kullanmanıza gerek olmayabilir . Örneğin Button
, ilk örnekteki bir işlevin click
geri çağrıyı bir DOM etkinliğine bağlamasını istiyorsanız, aşağıdakilerin tümü geçerli yöntemlerdir:
var myButton = {
... // As above
hookEvent(element) {
// Use bind() to ensure 'this' is the 'this' inside click()
element.addEventListener('click', this.click.bind(this));
}
};
Veya:
var myButton = {
... // As above
hookEvent(element) {
// Use a new variable for 'this' since 'this' inside the function
// will not be the 'this' inside hookEvent()
var me = this;
element.addEventListener('click', function() { me.click() });
}
};
Veya:
var myButton = {
... // As above
hookEvent(element) {
// => functions do not change 'this', so you can use it directly
element.addEventListener('click', () => this.click());
}
};
select = document.querySelector.bind(document)