【转载】JS中的bind 、call 、apply

function Person(name){

this.name = name;

}

var bindPerson = Person.bind({name:“绑定函数”})

new bindPerson(“张三”) // Person {name: “张三”}

5-1 预设参数

function fn(a,b,c,d){

console.log(a,b,c,d) // 1 ,2 ,3 ,4

}

var bindFn = fn.bind({name:“绑定函数”} , 1 ,2); // 拷贝原函数时的第2个参数开始往后称为预设参数

bindFn(3,4); //调用绑定函数时的第一参数则排在预设参数的后面

6-1 当没有参数、第一个参数为undefined、第一个参数为null时

var obj = {

fnOne:function(){ return this }.bind(),

fnTwo:function(){ return this }.bind( undefined ),

fnThree:function(){ return this }.bind( null )

}

//注意:这三种情况是使this指向window对象,而不是不去改变this指向,所以这里的this还是不会指向obj

obj.fnOne() // window

obj.fnTwo() //window

obj.fnThree() //window

二、call


特点:

1.返回值取决于目标函数的返回值

2.用call的第一个参数对象来代替调用目标函数的对象,以此来改变目标函数体内的this指向

3.调用call方法时的第二个参数做为目标函数的第一个参数,将第二个作为第三个以此类推

作用:

1.用于继承,例如子构造函数继承父构造函数

2.改变绑定函数运行时的this指针。

1-1 返回值取决于目标函数的返回值

function fn(){ return {name:“call”} }

fn.call() // {name: “call”}

2-1 改变目标函数体内的this指向 , 相当于使用第一个参数对象调用

function fn(){ return this }

fn.call( { name : “call” } ) // {name: “call”}

3-1 参数位置

function fn(a, b, c){ return arguments }

fn.call( { name : “call” } , 1 , 2 , 3 ) //Arguments [1, 2, 3]

1-2 用于继承

function parent(name, age) {

this.name = name;

this.age= age;

}

function child(name, age) {

parent.call(this, name, age);

this.class = ‘三年级二班’;

}

var xiaoming = new child(“小明” , 18)

三、apply


特点:

1.与call方法一样唯一不同的地方就是apply的第二个参数是一个数组,数组的第一个元素对应目标函数的第一个参数,以此类推

作用:

1.与call方法一样

1-1 参数

function fn(a, b, c){ return a+b+c }

fn.apply({name:“apply”} ,[1,2,3]) //6

其实前端开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

这里再分享一个复习的路线:(以下体系的复习资料是我从各路大佬收集整理好的)

《前端开发四大模块核心知识笔记》

最后,说个题外话,我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。

我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在IT学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值