[js]js设计模式-原型模式

Posted 毛台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[js]js设计模式-原型模式相关的知识,希望对你有一定的参考价值。

构造函数模型- 对象的属性和方法每人一份

function createJs(name, age) {
    this.name = name;
    this.age = age;
    this.writeJs = function () {
        console.log(this.name, this.age)
    }
}

p1 = new createJs("maotai", 22);
p1.writeJs();
p2 = new createJs("maotai2", 23);
p2.writeJs();

console.log(p1.writeJs===p2.writeJs);

原型模式- 对象的方法所有人共享一份

function createJs(name, age) {
    this.name = name;
    this.age = age;

}

createJs.prototype.writeJs = function () { //这个方法被所有对象共享
    console.log(this.name, this.age)
};

p1 = new createJs("maotai", 22);
p1.writeJs();
p2 = new createJs("maotai2", 23);
p2.writeJs();

console.log(p1.writeJs === p2.writeJs); //true



## 小结
类是函数, 函数有prototype
实例都是对象, 对象有__proto__属性
/*
*
* 1.每个函数数据类型(普通函数  类)都有个prototype属性,这个属性是一个对象数据类型的值
* 2.prototype上的浏览器天生给他加上了个constructor(构造函数),属性只是类本身
*     类:prototype
*         constructor
*         __proto__
* 3.每个对象都有__proto__属性
* 4.对象的__proto__指向所属类的原型
* 5.object原型上没有__proto__
* */

以上是关于[js]js设计模式-原型模式的主要内容,如果未能解决你的问题,请参考以下文章

js设计模式-原型模式

原型模式故事链--JS执行上下文变量提升函数声明

JS面向对象基础讲解(工厂模式构造函数模式原型模式混合模式动态原型模式)

[js]js设计模式-原型模式

js原型模式

js中创建对象方式----原型模式