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
特点:
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)
特点:
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学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。