js封装一个bind函数

实现之前应该明确下面几点:
- 接收的参数:第一个参数为this的指向,后面的参数就是函数接收的参数了。this是必需提供的参数,其他的参数都是非必需的;
- 返回值:返回值应该是一个函数;
实现代码:

function bind(fnc, context){
    var outerArgs = Array.prototype.slice.call(arguments,2); 
    //此处的arguments为调用此函数时传进来的参数;2代表只需要保存第二个参数之后的其他的参数
    return function(){ //返回值应该是一个函数
        var innerArgs = Array.prototype.slice.call(arguments);
        //此处的arguments为内部函数的参数
        var finalArgs = outerArgs.concat(innerArgs);
        return fnc.apply(context,finalArgs); //使用apply方法来改变this的指向
    }
}

好了,一个bind的封装就完成啦!嘻嘻嘻···

你可能感兴趣的:(前端学习,js)