时间:2021-05-26
本文实例讲述了JS中call和apply函数用法。分享给大家供大家参考,具体如下:
call 函数
语法
obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);
简介
thisObj继承obj的属性和方法(obj原型链上的属性和方法不能被继承),后面的参数会当成obj的参数安装顺序传递进去。
示例
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.sayHello = function(){ return 'hello'; }}function cat(name,type,nickname){ this.name = name; //cat继承animal animal.call(this,type,nickname);}console.log(new cat('wsscat','cut','tom'));apply 函数
语法
obj.apply(this[,argArray]);
简介
apply和call的作用差不多,都可以用来继承,区别在与apply只有两个参数,第二个参数必须是数组或者arguments对象。否则会报TypeError错误。如果继承的对象obj有多个参数,则会吧argArray的参数依次对应obj的每个参数。
示例
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.syaHello = function(){ return 'hello'; }}function cat(name,type,nickname){ this.name = name; animal.apply(this,arguments);}console.log(new cat('wsscat','cut','tom'));总结
call和apply在功能是相同的。
相同点在于都是用于对象的继承,第一个参数都是thisObj.
不同点在于call可以有多个参数,从第二个参数开始往后的参数会依次传给被继承的对象做参数。apply只有两个参数,第二个参数必须是数组类型或者arguments对象类型,而且他会把数组中的元素依次传递给被继承的对象做参数。
通过以上几点,我们可以得到如果被继承的对象只有一个参数的可以使用call,如果被继承的对象有多个参数的,建议使用apply.
补充
js中可以实现多继承,只需要调用多次call或apply即可。如:
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.syaHello = function(){ return 'hello'; }}function wscat(name,age){ this.name = name; this.age = age; this.sayMe = function(){ return 'my name:' + this.name + ', age:' + this.age; }}function cat(name,age,type,nickname){ //第一种使用call animal.call(this,type,nickname); wscat.call(this,name,age); //第二种使用apply //animal.apply(this,[type,nickname]); //wscat.apply(this,[name,age]);}console.log(new cat('wscat',2,'cat','tom');继承的优化
如果构造函数this绑定了太多的属性(比如一些共用的函数),示例化后就会照成浪费(因为this里的属性和方法实例化后会复制一份给新对象,多个对象之间的属性和方法互不干涉,对于一些可以共用的方法来就会造成浪费)
所以我们一般把共用的函数都放在原型链(prototype)上。但是使用call和apply无法继承原型链上的属性和方法。
因此我们可以使用混合的而写法,使用原型链和(apply或call)组合的方式进行继承。
让子的原型链指向父的示例(父的实例化对象)。如:
cat.prototype = new animal();让父的属性创建在子的this上。如:
animal.call(this[,arg]);//animal.apply(this[,argArray]);具体代码如下:
function animal(type,nickname){ this.type = type; this.nickname = nickname;}animal.prototype.sayHello = function(){ return 'hello';}function wscat(name,age){ this.name = name; this.age = age;} //这里是关键,原型链只能单继承,//不能同时继承多个原型链,所以要一级一级来。wscat.prototype = new animal();wscat.prototype.sayMe = function(){ return 'my name:' + this.name + ', age:' + this.age;}function cat(name,age,type,nickname){ animal.call(this,type,nickname); wscat.call(this,name,age);}cat.prototype = new wscat();var obj = new cat('wscat',10,'cat','tom');console.log(obj);//animal { type: 'cat', nickname: 'tom', name: 'wscat', age: 10 }console.log(obj.sayHello());//helloconsole.log(obj.sayMe());更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS中call()和apply()的功能及用法。分享给大家供大家参考,具体如下:1.call()和apply()的作用首先引出问题:用call()
本文实例分析了JavaScript函数apply()和call()用法与异同。分享给大家供大家参考,具体如下:JavaScript的函数是对象,因此有属性和方法
本文实例讲述了javascript中call,apply,callee,caller用法。分享给大家供大家参考,具体如下:实践一:call,apply用来让一个
call和apply方法call方法可改变上下文this指针,类似的方法还有apply,主要用在js对象各方法互相调用的时候,使当前this实例指针保持一致,或
本文实例讲述了python中__call__内置函数的用法。分享给大家供大家参考。具体分析如下:对象通过提供__call__(slef,[,*args[,**k