JS继承和apply高性能案例.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档