js的继承的方式

1.对象冒充继承

使用 bind,call,apply 解决构造函数属性的继承

缺点:不能继承原型上的属性和方法

js 复制代码
  //-------------父类-------------

        function Person(name, age, sex) {
            this.name = name;
            this.age = age;
            this.sex = sex;
        }

        Person.prototype.run = function () {
            console.log(`我${this.name},爱跑步!`);
        }
        
        //-------------子类-------------
        function Student(sNo, name, age, sex) {
            //对象的冒充
            // bind,call,apply
            Person.call(this, name, age, sex);
            //后面
            this.sNo = sNo;
        }

        var s1 = new Student(10001, "刘德华", 20, "男");
        console.log(s1);
        s1.run()

2.原型链继承

缺点:不能让构造函数的属性,初始化

js 复制代码
   //-------------父类-------------
      function Person(name, age) {
        this.name = name;
        this.age = age;
      }
      Person.prototype.name = "刘德海";
      Person.prototype.run = function () {
        alert(123);
      }

      //-------------子类-------------
      function Student() {
      }
      //我只实现了原型继承,构造函数内部的属性,是无法设置初始值
      Student.prototype = new Person();
      var s2 = new Student();
      console.log(s2);
      // s2.run()
      console.log(s2.address);

3.组合继承(对象冒充+原型链继承)

缺点:原型中会有多余的属性,并且是undefined

js 复制代码
   //-------------父类-------------
      function Person(name, age) {
        this.name = name;
        this.age = age;
      }
      Person.prototype.name = "刘德海";
      Person.prototype.run = function () {
        alert(123);
      }

      //-------------子类-------------
      function Student() {
      }
      //我只实现了原型继承,构造函数内部的属性,是无法设置初始值
      Student.prototype = new Person();
      var s2 = new Student();
      console.log(s2);
      // s2.run()
      console.log(s2.address);

4.寄生组合继承

寄生继承+对象冒充继承=寄生组合继承

寄生组合继承 Object.create(base.prototype);

js 复制代码
   // 寄生继承,解决原型问题
        // 寄生继承+对象冒充继承=寄生组合继承
        function inherit_proto(base, child) {
            // 1.创建父类原型,根据父类的原型,创建一个新的对象
            var basePrototype = Object.create(base.prototype);
            // 2.创建的原型对象,它的构造还是指向原来的构造函数
            // 我们就修改子类的构造器
            basePrototype.constructor = child
            // 3.让自己拥有父类的原型
            child.prototype = basePrototype
            console.log(basePrototype);
        }
        // 父类
        function Person(name, age, sex) {
            this.name = name
            this.age = age
            this.sex = sex
        }
        Person.prototype.sayHi = function () { }

        // 子类
        function Student(sNo, name, age, sex) {
            Person.call(this, name, age, sex)
            this.sNo = sNo
        }
        // 调用方法
        inherit_proto(Person, Student)
        var stu = new Student("1001", "小易", 22, "女")
        console.log(stu);

5.ES6的类+extends继承

js 复制代码
  class Person {
            constructor(name, age) {
                this.name = name
                this.age = age
            }
            run(){
                return  `跑步`
            }
        }
        class Student extends Person {
            constructor(name, age, sex) {
                super(name, age)
                this.sex = sex
            }
            // 重写:子类重写父类的方法
            run(){
                return  `哈哈哈哈哈哈或`
            }
        }
        var p=new Student("小易",22,"女")
        console.log(p.run());
        console.log(p);
相关推荐
JustHappy5 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
老毛肚5 小时前
jeecg-boot-base-core 02 day
javascript·python
snow@li5 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen6 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
小和尚同志6 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.07 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕7 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@7 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#9 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar9 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github