一、js面向对象程序
var o1 = new Object();
    o1.name = "宾宾";
    o1.sex = "男";
    o1.age = "27";
o1.msg = function(){
    console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
}
 
var o2 = new Object();
    o2.name = "倩倩";
    o2.sex = "女";
    o2.age = "20";
o2.msg = function(){
    console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
}
//调用对象下面方法
o1.msg();
o2.msg();
//思考:如何让代码复用。
//为了解决这个,引用一种设计模式:工厂模式。就是在函数内部创建一个对象,给对象赋予属性和方法,在将对象返回即可。
 
二、 工厂模式
//工厂模式是软件工程领域一种广为人知的设计模式,而由于在ECMAScript中无法创建类,因此用函数封装以特定接口创建对象。其实现方法非常简单,也就是在函数内创建一个对象,给对象赋予属性及方法再将对象返回即可。
function Person(name,sex,age){
    var o = new Object();
        o.name = name;
        o.sex = sex;
        o.age = age;
    o.getName = function () {
        console.log(this.name);
    }
    o.msg = function(){
        console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
    }
    return o;
}
var person1 = Person("彬彬","男","26");
//var myArray=new Array();
var person2 = Person("倩倩","女","26");
person1.msg();
person1.getName();
person2.msg();
//思考:我们创建的对象和系统对象有什么区别??
//为了解决这个:我们需要在外面new一个函数就可以了,这就引出了js另一种设计模式:构造函数模式
 
三、构造函数模式
//此模式特点:当new去调用一个函数,这个时候函数里面的this就是创建出来的对象,而且函数返回值直接就是this,这就叫隐式返回
function Person(name,sex,age){
    this.name = name;
    this.sex = sex;
    this.age = age;
    this.getName = function () {
        console.log(this.name);
    }
    this.msg = function(){
        console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
    }
}
var person1 = new Person("彬彬1","男","26");
var person2 = new Person("倩倩1","女","26");
person1.msg();
person1.getName();
person2.msg();
console.log(person1.msg == person2.msg);//false
//思考:如何在提供性能??也就是让公用的属性和方法在内存中只存在一份??
//解决问题方法:这里用到js设计模式中另外一种模式:原型模式。就是将公用的属性和方法加载在原型上(prototype)。
 
 
四、js原型模式
//原型(prototype)要写在构造函数下面。
//原型相当于CSS中Class,普通方法和属性相当于标签元素里的style。所以原型的优先级要普通方法和属性。
function Person(){
}
Person.prototype.name = "彬彬";
Person.prototype.sex = "男";
Person.prototype.age = "10";
Person.prototype.msg = function(){
    console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
}
var person1 = new Person();
person1.msg();
var person2 = new Person();
person2.name = "晃晃";
person2.msg();
//思考:这种修改属性比较麻烦???
//解决问题方法:把属性写在构造函数内,方法采用原型模式写,着就叫JS混合的模式
 
 
五、构造函数+原型的js混合的模式(推荐)
function Person(name,sex,age){
    this.name = name;
    this.sex = sex;
    if(age){
        this.age = age; //优先级高于原型
    }
}
Person.prototype.age = 10;
Person.prototype.getName = function(){
    console.log(this.name);
}
Person.prototype.msg = function(){
    console.log("姓名:"+this.name+"  性别:"+this.sex+"  年龄:"+this.age);
}
var person1 = new Person("彬彬1","男",80);
var person2 = new Person("倩倩1","女");
person1.msg();
person1.getName();
person2.msg();
console.log(person1.msg == person2.msg);//true

js设计模式:工厂模式、构造函数模式、原型模式、混合模式的更多相关文章

  1. 设计模式之第9章-原型模式(Java实现)

    设计模式之第9章-原型模式(Java实现) “快到春节了,终于快放假了,天天上班好累的说.”“确实啊,最近加班比较严重,项目快到交付了啊.”“话说一到过节,就收到铺天盖地的短信轰炸,你说发短信就发吧, ...

  2. .NET设计模式(6):原型模式(Prototype Pattern)(转)

    概述 在软件系统中,有时候面临的产品类是动态变化的,而且这个产品类具有一定的等级结构.这时如果用工厂模式,则与产品类等级结构平行的工厂方法类也要随着这种变化而变化,显然不大合适.那么如何封装这种动态的 ...

  3. NET设计模式 第二部分 创建型模式(5):原型模式(Prototype Pattern)

    原型模式(Prototype Pattern) ——.NET设计模式系列之六 Terrylee,2006年1月 概述 在软件系统中,有时候面临的产品类是动态变化的,而且这个产品类具有一定的等级结构.这 ...

  4. 设计模式(C#)——04原型模式

    推荐阅读:  我的CSDN  我的博客园  QQ群:704621321       在软件开发过程中,我们习惯使用new来创建对象.但是当我们创建一个实例的过程很昂贵或者很复杂,并且需要创建多个这样的 ...

  5. C#设计模式学习笔记:(5)原型模式

    本笔记摘抄自:https://www.cnblogs.com/PatrickLiu/p/7640873.html,记录一下学习过程以备后续查用.  一.引言 很多人说原型设计模式会节省机器内存,他们说 ...

  6. Java 设计模式系列(五)原型模式

    Java 设计模式系列(五)原型模式 原型模式属于对象的创建模式.通过给出一个原型对象来指明所有创建的对象的类型,然后用复制这个原型对象的办法创建出更多同类型的对象.这就是选型模式的用意. 一.原型模 ...

  7. .NET设计模式(6):原型模式(Prototype Pattern)

    ):原型模式(Prototype Pattern)    );         //使用颜色         string colorName = "red";         C ...

  8. 设计模式总结篇系列:原型模式(Prototype)

    首先对原型模式进行一个简单概念说明:通过一个已经存在的对象,复制出更多的具有与此对象具有相同类型的新的对象. 在理解Java原型模式之前,首先需要理解Java中的一个概念:复制/克隆. 在博文< ...

  9. 设计模式之(六)原型模式(ProtoType)

    认识原型模式 原型模式是比较简单的设计模式.废话不多说,直接看定义:用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象.通过实例指定种类,种类就是初始化的类,然后通过拷贝创建对象.先展示一个 ...

  10. 设计模式学习-使用go实现原型模式

    原型模式 定义 代码实现 优点 缺点 适用场景 参考 原型模式 定义 如果对象的创建成本比较大,而同一个类的不同对象之间差别不大(大部分字段都相同),在这种情况下,我们可以利用对已有对象(原型)进行复 ...

随机推荐

  1. 解决pycharm无法导入本地包的问题

    在用python写爬虫程序时,import 行无法通过,具体情况如下: pycharm运行程序后,程序pass了,但是出现了警告,如下图所示: 这是由于该程序不在根目录下,无法导入本地包,解决办法如下 ...

  2. 06 hash join (Oracle里的哈希连接原理)

    hash join (Oracle里的哈希连接原理) 2015年09月25日 17:00:28 阅读数:2188 哈希连接(HASH JOIN)是一种两个表在做表连接时主要依靠哈希运算来得到连接结果集 ...

  3. mvc上传图片(上传和预览)webuploader

    笔者看到mvc最近比较流行,而很多使用一些比较旧的的方法上传图片,再次安利一下百度的webuploader控件吧 webuploader第一步要先下载一些插件这点可以在webuploader官网上下载 ...

  4. meven 配置

    配置meven 自定义文件[User Settings] D:\java\apache-maven-3.5.3\conf\settings.xml settings.xml 新增两端配置信息 < ...

  5. jQuery.qrcode 生成二维码,并使用 jszip、FileSaver 下载 zip 压缩包至本地。

    生成二维码 引用 jquery.qrcode.js  :连接:https://files.cnblogs.com/files/kitty-blog/jquery.qrcode.js .https:// ...

  6. 关于vue中mockjs的使用

    使用vue的时候,后台可能不能及时作出接口,那么就需要我们前端自己模拟数据,使用mockjs可以进行模拟数据. 首先安装mockjs,cnpm install mockjs --save-dev: 其 ...

  7. webuploader的一个页面多个上传按钮实例

    借鉴一位大佬的demo  附上他的github地址https://github.com/lishuqi 我把他的cxuploader.js改了不需要预览  直接上传图片后拿到回传地址给img标签显示图 ...

  8. 能够还原jQuery1.8的toggle的功能的插件

    下面这个jQuery插件能够还原1.8的toggle的功能,如果你需要,可以直接把下面这段代码拷贝到你的jQuery里面,然后跟平时一样使用toggle的功能即可. //toggle plugin f ...

  9. yii学习笔记(4),获取请求数据的request组件

    yii在控制器中获取请求数据需要通过request组件来完成 <?php namespace app\controllers; use yii; use yii\web\Controller; ...

  10. Dubbo client 启动报错:No provider available for the service use dubbo version 2.5.3

    1.异常 java.lang.IllegalStateException: Failed to check the status of the service org.ko.server.servic ...