当前位置: 首页 > news >正文

建设银行常熟支行网站安徽网站备案手续

建设银行常熟支行网站,安徽网站备案手续,商标注册号怎么申请,网站做线1.原型链继承 实现原理:子类的原型指向父类实例。子类在自身实例上找不到属性和方法时去它父类实例(父类实例和实例的原型对象)上查找,从而实现对父类属性和方法的继承 缺点: 子类创建时不能传参(即没有…

1.原型链继承

实现原理:子类的原型指向父类实例。子类在自身实例上找不到属性和方法时去它父类实例(父类实例和实例的原型对象)上查找,从而实现对父类属性和方法的继承

缺点:

  • 子类创建时不能传参(即没有实现super()的功能);
  • 父类实例的修改会影响子类所有实例
        function Parent(name){this.name = "父级的name";}Parent.prototype.getName = function(){console.log("getName:"+this.name);}function Child(){}// 子类原型指向父类的实例Child.prototype = new Parent();Child.prototype.constructor = Child;//这句话和原型链继承没有关系,只是根据原型链规则绑定constructor// 测试var child = new Child();console.log(child.name);//父级的namechild.getName();//getName:父级的name// 缺点:不能传参;父类实例改变子类所有实例也改变

2.构造函数继承

实现原理:子类构造函数中执行父类的构造函数,并且为父类构造函数绑定子类的this,父类的构造函数把成员属性和方法都挂到子类的this上去,这样既能避免实例之间共享一个原型实例,又能向父类构造方法传参

缺点:无法继承父类原型上的属性和方法

        // 构造函数继承function Parent(name) {this.name = name;console.log("父类构造函数");}Parent.prototype.getName = function () {console.log("getName:" + this.name);}function Child(name){Parent.call(this, name);}var child = new Child("张三");console.log(child);//Child {name: '张三'}// 不能继承父类原型上的方法和属性child.getName();//报错,child.getName is not a function

3.组合式继承

实现原理:原型链继承+构造函数继承

缺点:父类构造函数会执行两次(Parent.call()和new Parent()),这不影响子类对父类的继承,但是每次创建子类实例时原型中都会有两份相同的属性和方法

        // 组合式继承:原型链继承+构造函数继承function Parent(name) {this.name = name;console.log("父类构造函数");}Parent.prototype.getName = function () {console.log("getName:" + name);}function Child(name) {Parent.call(this, this.name);}Child.prototype = new Parent();Child.prototype.constructor = Child;var child = new Child("张三");console.log(child);//Child {name: '张三'}child.getName();

 

4.寄生式组合继承

实现原理:父类构造函数会执行两次(Parent.call()和new Parent()),那么在原型链继承时就只继承父类的原型,就不会执行两次父类构造函数  Child.prototype = Parent.prototype;

缺点:操作子类原型对象,会影响到父类原型对象,例如给Child.prototype增加一个getName()方法,那么会导致Parent.prototype也增加或被覆盖一个getName()方法

        // 寄生式组合继承:原型链继承(只继承父类原型)+构造函数继承function Parent(name) {this.name = name;}Parent.prototype.getName = function () {console.log("getName:" + this.name);}function Child(name) {Parent.call(this, name);}Child.prototype = Parent.prototype;Child.prototype.constructor = Child;var child = new Child("张三");console.log(child);//Child {name: '张三'}child.getName();

4.1解决寄生式组合继承的缺点(使用Object.create()进行继承) 

如下,对Child.prototype.getName子类中原型上属性或方法进行修改时,父类也被修改

        function Parent(name) {this.name = name;console.log("父类构造函数");}Parent.prototype.getName = function () {console.log("父类getName");}function Child(name) {Parent.call(this, name);}Child.prototype = Parent.prototype;Child.prototype.constructor = Child;Child.prototype.getName = function(){console.log("子类getName");}var child = new Child("张三");console.log(child);//Child {name: '张三'}child.getName();var parent = new Parent("李四");parent.getName();

 

解决:加上Object.create()方法即可

        // Child.prototype = Parent.prototype;Child.prototype = Object.create(Parent.prototype);

 

5.ES6的Class继承

实现原理:ES6新增,是ES5中构造函数+原型链继承组合继承,寄生组合式继承的结合

缺点:兼容性不好

6.扩展——对象的几种创建方式

  • 字面量创建
  • var obj = new Object()创建
  • 构造函数创建
  • Object.create()创建
        // 字面量创建let obj1 = {name: 'lmf1',say() {console.log("lmf1 say");}}// new Object()创建let obj2 = new Object({name: 'lmf2',say() {console.log("lmf2 say");}});// 构造函数创建function Person(name) {this.name = name;}let obj3 = new Person("lmf3");Person.say = function () {console.log("静态方法");}Person.prototype.say = function () {console.log("lmf3 say");}// Object.create()创建let obj4 = Object.create(obj3);console.log(obj1, obj2, obj3, obj4);

http://www.yayakq.cn/news/507086/

相关文章:

  • 做网站怎么做重庆公司注销的流程及需提供的材料
  • 网上购物网站开发六安短视频优化费用
  • 网站收缩目录模板黑龙江国际旅行社电话
  • 网络公司做的网站我能改后台么徐州通域网架公司
  • 怎么做推广赚佣金怎么给别人做网站优化
  • wordpress改后台登录地址西安做网站优化
  • 镇江网站制作优化jsp网站开发心得
  • 做网站想注册商标是哪一类wordpress小说
  • 工业设计作品集网站便宜网站建设
  • pc开奖网站建设wordpress免签支付插件
  • 深圳龙华做网站网站建设题目以及答案
  • 保定网站建设模板联系方式二维码网站制作
  • 留言网站建设的报告只买域名怎么做网站
  • 合肥建行网站系统的网站建设教程
  • 如何做网站手机潮州网站搭建找谁
  • 静态html网址网站导航源码漳州专业网站建设公司
  • 支付宝接口 网站备案广州建网站哪里比较好
  • 成都o2o网站建设好的建筑设计公司
  • html5手机论坛网站模板wordpress纯手工注入
  • 社区网站建设方案书膳食管理东莞网站建设
  • 华硕路由器做网站天津市城乡建设局网站
  • 网站备案完成后接下来怎么做h5响应式网站做动画
  • 网站设计中的div是什么如何做旅游网站推销
  • 大气网站后台界面8+1网站正能量直接入口没封
  • 组成原理毕业设计代做网站推荐郑州企业建站系统模板
  • 网络建站 响应式网站国外有哪些做服装的网站有哪些方面
  • 网站初期 权重怎么做响应适网站开发
  • 企业网站推广的收获与启示长沙市网站建设公司代理商
  • 如何加强省市级政门户网站建设wordpress新闻模板
  • 网站开发工作怎么样安阳网站建设兼职