首页 > 其他 > 详细

原型(prototype)

时间:2021-05-12 14:29:22      阅读:17      评论:0      收藏:0      [点我收藏+]

原型(prototype)

  • 在JavaScript中,每个函数都有一个prototype属性,这个属性指向函数的原型对象。

  • JavaScript不区分类和实例的概念,而是通过原型(prototype)来实现面向对象编程。

  • var student = {
        name:‘lisi‘,
        age:18,
        run:function(){
            console.log(this.name + "run...");
        }
    };
    var xiaoming = {
        name:‘xiaoming‘
    }
    //_proto_:这是每个对象(除null外)都会有的属性,这个属性会指向该对象的原型。
    //设置xiaoming原型为student,有相同属性则修改,没有则继承`
    
    xiaoming._proto_ = student;
    console.log(xiaoming); //name:xiaoming,age:18,run...
    
  • class的继承

    • ES6引入,语法与Java继承类似,本质还是查看对象原型。
    //ES6之前
    //prototype
    function Student(name) {
        this.name = name;
    }
    // 现在要给这个Student新增一个方法
    Student.prototype.hello = function () {
        alert(‘Hello, ‘ + this.name + ‘!‘);
    }
    

    ? 定义一个学生类

    //定义一个学生类
    class Student {
        constructor(name) {
            this.name = name;
        }
        hello() {
            alert(‘hello‘);
        }
    }
    var zs = new Student(‘zhangshan‘);
    var xm = new Student(‘xiaoming‘);
    

    ? 继承

    //定义一个学生类
    class Student {
        constructor(name) {
            this.name = name;
        }
        hello() {
            alert(‘hello‘);
        }
    }
    
    class postGraduate extends Student {
        constructor(name, grade) {
            super(name); // 记得用super调用父类的构造方法!
            this.grade = grade;
        }
        myGrade() {
            alert(‘I am a postGraduate ‘ + this.grade);
        }
    }
    var xh = new postGraduate(‘小李‘,‘大一‘);
    

    ? 本质对象

    ? 技术分享图片

原型(prototype)

原文:https://www.cnblogs.com/saxonsong/p/14758301.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!