js中bind的实现

function person(a,b,c) {
    console.log(this.name);
    console.log(a,b,c);
}
let p = { name:'张三' }

Function.prototype.newBind=function (object) {
    if(typeof this !='function'){
        throw new TypeError('错误')
    }
    let temp = this,//当newbind被new了之后这里的this就不是指向person了而是指向实例,发生了new构造
    // arguments是对象不能使用数组切割第一个参数
    // Array.prototype.slice.call()将有length属性的对象转化为数组
    arr=Array.prototype.slice.call(arguments,1),
    o=function(){},
   newf= function(){
    let arr2=Array.prototype.slice.call(arguments),
    sumArr=[...arr,...arr2]
    if(this instanceof o){//判断有没有使用new绑定,有的话就绑定到新实例上
    temp.apply(this,sumArr)
    }else{//没有的话就绑定到原来的object对象上
    temp.apply(object,sumArr)
    }
   }
   o.prototype=temp.prototype//将person的函数原型对象赋值给o
   newf.prototype=new o//再将新函数newf的原型对象作为空函数o的实例进行串联
   return newf
}
const newBind=person.newBind(p,'1','2')
const nb=new newBind('3')
//undefined
//1 2 3
const bind=person.bind(p,'1','2')
const b=new bind('3')
//undefined
//1 2 3
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值