学习笔记-call&apply&bind

let dog = {
    name:'teddy',
    eat:function(arr1,arr2){
        console.log(arg1+arg2)
        console.log(this)
    }
}
  • apply
dog.eat.apply({a1:1,a2:2},[1,2])
// console.log(arg1+arg2) 
// 1+2=3
// console.log(this)
// {a1:1,a2:2}
  • call
dog.eat.call({a1:3,a2:4},1,2)
// console.log(arg1+arg2) 
// 1+2=3
// console.log(this)
// {a1:3,a2:4}
  • bind
let newfn = dog.eat.bind({a1:4,a2:5})
newfn(6,7)
// console.log(arg1+arg2) 
// 6+7 = 13
// console.log(this)
// {a1:4,a2:5}

new 过程模拟

function A(a,b){
    this.a = a
    this.b = b
}

A.prototype.eat = function(){
    console.log(this.a+"xxx")
}

function myNew(fn,...args){
    // 构造一个新obj
    let obj = {}
    // 绑定__proto__
    //obj.__proto__ = fn.prototype
    Object.setPrototypeOf(obj,fn.prototype)
    // 执行构造函数
    // this.a=a 
    // this.b=b
    fn.call(obj,...args)
    // 返回
    return obj
}

// let a= new A(2,3)
let a = myNew(A,2,3)
a.eat()  // 2xxx

类数组

let obj = {
    0:"xx1",
    1:"xx2",
    2:"xx3",
    length:3
}

// 模拟filter
Array.prototype.myFilter = function(callback){
    let newArr = []
    for(let i=0;i<this.length;i++){
        if(callback(this(i))){
            newArr.push(this[i])
        }
    }
    return newArr
}

let res = [].myFilter.call(obj,item=>item.indexOf("1")!=-1)
console.log(res)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值