js中call,apply,bind的实现原理()

Posted IT猩

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中call,apply,bind的实现原理()相关的知识,希望对你有一定的参考价值。

// js中call,apply,bind的实现原理()
// 三者的区别,都是改变this指针,call和apply主要是参数区别,bind返回的是一个函数体,而call和apply是立即执行
// call的实现
function fn1 (str1,str2,str3){
console.log(this,str1,str2,str3);
}
function fn2(){

}
Function.prototype.call = function (context){
    // 避免传入的是基本类型,使用object进行对象化
    context = context ? Object(context) : window;
    context.fn = this;
    let args = [];
    for (let i = 1;i<arguments.length;i++) {
        args.push('arguments[' + i + ']');
    }
    // es数组的结构
    let r = eval("context.fn("+args + ")");
    delete context.fn;
    return r;
}
fn1.call('hellow',1,2,3);

// apply的实现原理
Function.prototype.apply = function (context,args){
// 避免传入的是基本类型,使用object进行对象化
context = context ? Object(context) : window;
context.fn = this;
if (args) {
return eval("context.fn("+args + ")");
}
let argss = [];
for (let i = 1;i<arguments.length;i++) {
argss.push(‘arguments[‘ + i + ‘]‘);
}
// es数组的结构
let r = eval("context.fn("+args + ")");
delete context.fn;
return r;
}
fn1.apply(‘hellow‘,[1,2,3]);
//bin的实现的话,改变函数不要立即执行就可以

以上是关于js中call,apply,bind的实现原理()的主要内容,如果未能解决你的问题,请参考以下文章

原生JS实现call,apply,bind函数

绑定this:call()apply()bind()和它们的内部实现原理 + 箭头函数中的this

绑定this:call()apply()bind()和它们的内部实现原理 + 箭头函数中的this

js 难点之call,apply,bind实现

JS中的call,apply和bind及记忆方式

手写JS面试题 --- call apply bind 实现