简体   繁体   中英

How to bind an object to a function in JavaScript?

I have the next task:

const person = {name: 'Arnold'};

function fn(salut, lastName) {
    console.log(salut, this.name, lastName);
}

const bindName = bind(fn, person, 'Mr');

bindName('Helgov');

I have to write a function that prints: "Mr Arnold Helgov"

My realization of this task is the next function:

function bind(fn, person, salute) {
    return (lastname) => {
        return fn(salute, lastname);
    }
}

But I have a problem here. My function prints only "Mr Helgov" and the name 'Arnold' is lost. How to solve this problem (maybe by using bind or apply or call )?

How to solve this problem (maybe by using bind or apply or call )?

Yes, you can use call or bind to make sure this gets to be equal to person during the call of fn .

With call :

 const person = {name: 'Arnold'}; function fn(salut, lastName) { console.log(salut, this.name, lastName); } const bindName = bind(fn, person, 'Mr'); bindName('Helgov'); function bind(fn, person, salute) { return (lastname) => { return fn.call(person, salute, lastname); } }

Or, bind :

 const person = {name: 'Arnold'}; function fn(salut, lastName) { console.log(salut, this.name, lastName); } const bindName = bind(fn, person, 'Mr'); bindName('Helgov'); function bind(fn, person, salute) { return fn.bind(person, salute); }

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM