javascript 面向对象编程(工厂模式、构造函数模式、原型模式)
javascript 面向对象编程(工厂模式、构造函数模式、原型模式)
CreateTime--2018年3月29日17:09:38
Author:Marydon
一、工厂模式
/**
* 工厂模式
*/
function factoryFunction() {
// 1.创建一个Object对象(人)
var person = new Object();
// 或者 var person = {};
// 2.对象的属性(对应人的特征)
person.name = "Marydon";
person.qq = "2982586911";
person.website = "www.cnblogs.com/Marydon20170307";
// 3.对象的方法(对应人的行为)
person.operation = function() {
alert("正在演示工厂模式");
};
return person;
}
调用:
factoryFunction().operation();
适用场景:
个人不推荐使用,因为构造函数模式完全可以取代。
二、构造函数模式
/**
* 构造函数模式
* @注意:首字母要大写,用于和普通函数区分
*/
function ConstructorFunction() {
this.name = "Marydon";
this.qq = "2982586911";
this.website = "www.cnblogs.com/Marydon20170307";
// 这个两个this指的是同一对象哦!
this.operation = function() {
alert(this.name);
}; }
调用:
// 创建对象,对象创建后,该对象里面的this指的就是cf
var cf = new ConstructorFunction();
cf.operation();// 弹出Marydon
适用场景:
个人比较推荐使用
三、原型模式
/**
* 原型模式
* @注意:使用前,必须实例化
*/
function prototypeFunction() {};
prototypeFunction.prototype.name = "Marydon";
prototypeFunction.prototype.qq = "2982586911";
prototypeFunction.prototype.website = "www.cnblogs.com/Marydon20170307"; prototypeFunction.prototype.operation = function() {
alert("正在演示原型模式");
};
调用:
// 不能这样直接调用
// prototypeFunction().operation();
// 必须得先创建这个对象
var pf = new prototypeFunction();
适用场景:
给已经存在的对象添加方法时使用
比如:String对象没有trim()方法,Date对象没有format()方法,对其进行自定义封装时,需要用到。
四、还用一种经常使用
/**
* 使用JSONObject创建
*/
var jsonObjectFunction = {
name :"Marydon",
qq : "2982586911",
website : "www.cnblogs.com/Marydon20170307",
operation : function() {
alert("正在演示JSON对象");
} };
调用:
// 直接调用
jsonObjectFunction.operation();
适用场景:
比较典型的就是ajax函数对象,另外,许多封装的插件也是使用的这种方式。
五、结语
很多时候需要混合使用,最常见的是:构造函数+原型函数 模式
javascript 面向对象编程(工厂模式、构造函数模式、原型模式)的更多相关文章
- (三)Javascript面向对象编程:非构造函数的继承
Javascript面向对象编程:非构造函数的继承 这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现"继承". 今天是最后一个部分,介绍不使 ...
- javascript面向对象系列第一篇——构造函数和原型对象
× 目录 [1]构造函数 [2]原型对象 [3]总结 前面的话 一般地,javascript使用构造函数和原型对象来进行面向对象编程,它们的表现与其他面向对象编程语言中的类相似又不同.本文将详细介绍如 ...
- Javascript 面向对象编程2:构造函数的继承
这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例.对象之间的"继承"的五种方法.比如,现在有一个"动物"对象 ...
- 转载:javascript面向对象编程:非构造函数的继承
一.什么是"非构造函数"的继承? 比如,现在有一个对象,叫做"中国人". var Chinese = { nation:'中国' }; 还有一个对象,叫做&qu ...
- Javascript面向对象编程:非构造函数的继承
今天是最后一个部分,介绍不使用构造函数实现"继承". 一.什么是"非构造函数"的继承? 比如,现在有一个对象,叫做"中国人". var Ch ...
- (二)Javascript面向对象编程:构造函数的继承
Javascript面向对象编程:构造函数的继承 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继承 ...
- Javascript面向对象编程(二):构造函数的继承 作者:yuan一峰
Javascript面向对象编程(二):构造函数的继承 作者: 阮一峰 日期: 2010年5月23日 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生 ...
- JavaScript面向对象编程(一)原型与继承
原型(prototype) JavaScript是通过原型(prototype)进行对象之间的继承.当一个对象A继承自另外一个对象B后,A就拥有了B中定义的属性,而B就成为了A的原型.JavaScri ...
- JavaScript面向对象编程(二)构造函数和类
new关键字和构造函数 在文章JavaScript面向对象编程(一)原型与继承中讨论啦JavaScript中原型的概念,并且提到了new关键字和构造函数.利用new关键字构造对象的实例代码如下: // ...
随机推荐
- 按考分对学生排序 Exercise08_03
/** * @author 冰樱梦 * 时间:2018年12月 * 题目:按考分对学生排序 * */ public class Exercise08_03 { public static void m ...
- 参加SAP VT项目有感
凡事预则立,不预则废. 没有接到录取电话还是有些悲伤的,虽然知道最终被录取的可能性不大,但是之前还是抱着一丝期望的,毕竟是自己的处女面,就这么以失败的结果结束了. 从最开始的投递简历,到后来的电话面试 ...
- mvc-单例多线程模式
以spring mvc 为例子 spring mvc 的Controller类默认Scope是单例(singleton) 测试结果发现spring3中的controller默认是单例的,若是某个con ...
- css背景图片模糊
index.html <image class="bg" src="/images/bg.png"></image> index.css ...
- 让ios项目同时支持ARC和非ARC
ttp://code4app.com/snippets/one/禁止某几个文件用ARC模式编译/502344256803fa246d000000#s0 如果你的绝大部分代码需要ARC,那么就设置项目支 ...
- Shell升级,/bin/bash版本号4.1到4.3
bash环境变量存在随意代码运行漏洞:"通过CGI请求方式能够导致远程代码运行,进而导致server被入侵.危害严重.且官方发布补丁也被绕过", [漏洞影响]: 1)bash受影响 ...
- JAVAssist---动态改动注解
ITOOV3.0開始了,须要研究一些技术难点,先来说一个我认为比較有趣的技术点吧.需求是这种.我们须要动态的切换数据源,又因为我们是通过实体单元的注入来完毕的.实体单元是通过注解的形式注入的.这样假 ...
- SourceInsight中文字体
转载自: http://blog.chinaunix.net/uid-29094179-id-3889999.html 1.正确显示中文注释 1)Options->Style Propertie ...
- 【资料】wod旗帜,纹章
物品 徽章 旗帜 掉落地点 备注 火焰纹章 法师与怪物 火焰魔法.魔法攻防 雄鹰纹章 受诅咒的遗迹 弩系相关 盗贼纹章 捉迷藏 偷袭.匕首.割喉.近攻防 守夜人的纹章 酒馆里平静的一天 钝器.双打.旋 ...
- FAQ:如何修改领域模型?
问答部分 问: 如何修改领域模型? 答: 一般来说我们有两种选择,这两种选择也是两种价值观的体现(乐观和悲观). 第一种:使用UI传递过来的DTO在应用层重建Domain Model,然后执行修改,D ...