文章转载自:http://www.qdfuns.com/notes/26042/e93934ad4e6c67ea2d8b1e2d2af12d3d.html
1、apply 与 call 是作用是什么,有何区别
apply 与 call 最经常用于对象的继承中,两者的写法分别是
testObj.apply(obj,argArray)
testObj.call(obj , arg1,arg2,arg3)
说明:将testObj 的作用域替换 当前 obj的。
区别:有上面可看出apply与call的区别在于传参的形式不一样。两者第一个参数都是要被替换的对象,不同的后续参数apply
是要传入数组,而call传入的是每一个单独的参数。
话不多说,我们现在抛出一个栗子
var people = function(name){
this.name = name;
this.tellName = function(){
console.log("my name is "+this.name);
}
}
var student = function (name,doSomthing){
people.call(this,name) //此处将使用call继承了people的属性与方法
this.do = function() {
console.log(doSomthing);
}
}
var xiaoming = new student("小明","做作业");
console.log(xiaoming.name); //小明
xiaoming.tellName(); //my name is 小明
xiaoming.do(); // 做作业
var people = function(name){
this.name = name;
this.tellName = function(){
console.log("my name is "+this.name);
}
}
var student = function (name,doSomthing){
people.apply(this,[name]) //此处将使用apply继承了people的属性与方法,与上面的不一样就在最后传参的方式。
this.do = function() {
console.log(doSomthing);
}
}
var xiaoming = new student("小明","做作业");
console.log(xiaoming.name); //小明
xiaoming.tellName(); //my name is 小明
xiaoming.do(); // 做作业
我们可以看两者结果都会是一样的。