CALL
- Call invokes the function and allows you to pass in arguments one by one.
- Gọi hàm và cho phép bạn truyền vào một object và các đối số phân cách nhau bởi dấu phẩy (Comma)
1 2 3 4 5 6 7 8 9
| var person1 = {firstName: 'Jon', lastName: 'Kuperman'}; var person2 = {firstName: 'Kelly', lastName: 'King'};
function say(greeting1, greeting2) { console.log(greeting1 + ',' + greeting2 + ' ' + this.firstName + ' ' + this.lastName); }
say.call(person1, 'Hello', 'Good morning'); say.call(person2, 'Hello', 'Good morning');
|
APPLY
- Apply invokes the function and allows you to pass in arguments as an array.
- Gọi hàm và cho phép bạn truyền vào một object và các đối số thông qua mảng (Array)
1 2 3 4 5 6 7 8 9
| var person1 = {firstName: 'Jon', lastName: 'Kuperman'}; var person2 = {firstName: 'Kelly', lastName: 'King'};
function say(greeting0, greeting1) { console.log(greeting0 + ',' + greeting1 + ' ' + this.firstName + ' ' + this.lastName); }
say.apply(person1, ['Hello', 'Good moring']); say.apply(person2, ['Hello', 'Good moring']);
|
BIND
- Bind returns a new function, allowing you to pass in a this array and any number of arguments.
- Trả về một hàm số mới, cho phép bạn truyền vào một object và các đối số phân cách nhau bởi dấu phẩy.
1 2 3 4 5 6 7 8 9 10 11 12
| var person1 = {firstName: 'Jon', lastName: 'Kuperman'}; var person2 = {firstName: 'Kelly', lastName: 'King'};
function say(greeting0, greeting1) { console.log(greeting0 + ',' + greeting1 + ' ' + this.firstName + ' ' + this.lastName); }
var sayHelloJon = say.bind(person1, 'Hello', 'Good morning'); var sayHelloKelly = say.bind(person2, 'Hello', 'Good morning');
sayHelloJon(); sayHelloKelly();
|
https://codeplanet.io/javascript-apply-vs-call-vs-bind/