- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JS继承和apply高性能案例
本文档包含:
JS继承
Apply的高性能案例
一,js中对象继承
?
1.js原型(prototype)实现继承?
代码如下:
function person(name,age){
this.name=name;
this.age=age;
}
person.prototype.say=function(){
document.writeln(使用父亲原型得到名字:+this.name);
}
var p1=new person(张三,10);
p1.say();
//创建child对象
function child(){}
child.prototype=new person(继承自person,20);
child.prototype.grade=5;
//实例化这个对象,否则无效
var child=new child();
child.say();//输出:使用父亲原型得到名字:继承自person ?
2.构造函数实现继承
代码如下:
function person(name){
this.name=name;
this.sayp=function(){
document.writeln(使用父亲原型得到名字:+this.name);
}
}
var p=new person(baba);
p.sayp();
function child(name,age){
this.method=person;
this.method(name);
this.age=age;
this.sayc=function(){
document.writeln(使用child构造函数名字:+this.name);
}
}
var child=new child(孩子,8);
child.sayc();//输出:使用父亲原型得到名字:继承自person
?
3.call , apply实现继承
代码如下:
SPAN style=FONT-SIZE: 18pxhtml ?
body ?
script type=text/javascript ?
? ? function ?Person(name,age,love){ ?
? ? ? ? this.name=name; ?
? ? ? ? this.age=age; ?
? ? ? ? this.love=love; ?
? ? ? ? this.say=function say(){ ?
? ? ? ? ? ? alert(姓名:+name); ?
? ? ? ? } ?
? ? } ?
?
? ? //call方式 ?
? ? function student(name,age){ ?
? ? ? ? Person.call(this,name,age); ?
? ? } ?
?
? ? //apply方式 ?
? ? function teacher(name,love){ ?
? ? ? ? Person.apply(this,[name,love]); ?
? ? ? ? //Person.apply(this,arguments); //跟上句一样的效果,arguments ?
? ? } ?
?
? ? //call与aplly的异同: ?
? ? //1,第一个参数this都一样,指当前对象 ?
? ? //2,第二个参数不一样:call的是一个个的参数列表;apply的是一个数组(arguments也可以) ?
?
? ? var per=new Person(武凤楼,25,魏荧屏); //输出:“武凤楼” ?
? ? per.say(); ?
? ? var stu=new student(曹玉,18);//输出:“曹玉” ?
? ? stu.say(); ?
? ? var tea=new teacher(秦杰,16);//输出:“秦杰” ?
? ? tea.say(); ?
?
/script ?
/body ?
/html/SPAN ?
?
二、call和apply的用法(详细介绍)
?call和apply
js中call和apply都可以实现继承,唯一的一点参数不同,func.call(func1,var1,var2,var3)对应的apply写法为:func.apply(func1,[var1,var2,var3])。
?
JS手册中对call的解释:
?
?代码如下:
SPAN style=FONT-SIZE: 18pxcall 方法 ?
调用一个对象的一个方法,以另一个对象替换当前对象。 ?
?
? ? call([thisObj[,arg1[, arg2[, ? [,.argN]]]]]) ?
?
参数
原创力文档


文档评论(0)