/**
* 顺便重温一下对象的创建方式
* 代码简单说明问题就好
* 概念性的东西这里就不提了,只加上自己简单理解
*/ /**
* 工厂模式,就是将手动的创建细节封装在一个方法里,
* return出来一个实例。
* 所谓工厂就是封装创建工程,得到实例。
* 缺点:不能判断对象类型,因为得到的类型都是Object,
* 不能知道是否createPerson的实例
* 是否某对象的实例的判断其实就是实例的原型是否指向对象
* */ function createPerson(name){
var p = new Object();
p.name = name;
p.say = function(){
alert(this.name);
};
return p;
}
var p1 = createPerson('p1'); /**
* 构造函数模式:与工厂的不同是不用显式的去new一个对象
* 因为不管什么函数,只要使用new来调用都起到构造函数的作用。
* 实例可以通过 instanceof Person 来获得对象类型.
* 缺点:每个方法都要在实例上创建一遍
* */
function Person(name){
this.name = name;
this.say = function(){
alert(this.name);
}
}
var p2 = new Person('p2');
console.log(p2 instanceof Person);//true
/**
* 原型模式
* 简单粗暴原型链。
* 对应上述的,原型的方法,各个实例共享相应的属性或方法
* 缺点就是属性修改既影响其他
* */
function Cat(){ }
Cat.prototype.name = 'catName';
Cat.prototype.age = 'catAge';
Cat.prototype.say = function(){
alert(this.name);
}; var c1 = new Cat(); console.log(c1 instanceof Cat);//true
/**
* 组合构造函数和原型模式
* 为了解决上面的问题混合使用两种方式
* 该私有的私有,该共享的共享
* */ function Cat1(name){
this.name = name;
}
Cat1.prototype.say = function(){
alert(this.name);
}; var c2 = new Cat1('c2');
console.log(c2 instanceof Cat1);//true /**
* 动态原型模式
* 判断属性是否存在,来决定式否增加原型属性
* 和混合模式类似
* */ function Cat2(name){
this.name = name;
if(typeof this.say != 'function'){
Cat2.prototype.say = function(){
alert(this.name);
}
}
} var c3 = new Cat2('c2');
console.log(c3 instanceof Cat2);//true
/**
* 寄生虫构造函数模式:
* 函数封装创建对象的代码,返回创建的对象。
* 这里于工厂模式的区别在于要通过new 来实例化。本质上是一样的。
* 不可以判断对象类型:
* */
function Dog(name){
var d = new Object();
d.name = name;
d.say = function(){
alert(this.name);
};
return d;
}
var d = new Dog('d');
console.log(d instanceof Dog);//false /**
* 稳妥构造函数模式:安全
* 没有公共属性,方法不引用this。不使用new来实例化对象
* */
function Dog1(name){
var d = new Object();
d.say = function(){
alert(name);
};
return d;
}
var d2 = Dog1('a');
console.log(d2 instanceof Dog1);//false

js创建对象的几种方式的更多相关文章

  1. js创建对象的三种方式和js工厂模式创建对象

    文章地址: https://www.cnblogs.com/sandraryan/ 创建对象 创建对象的三种方式 构造函数 ,是一种特殊的方法.主要用来在创建对象时初始化对象 1. 调用系统的构造函数 ...

  2. 第184天:js创建对象的几种方式总结

    面向对象编程(OOP)的特点: 抽象:抓住核心问题 封装:只能通过对象来访问方法 继承:从已有的对象下继承出新的对象 多态:多对象的不同形态 一.创建对象的几种方式 javascript 创建对象简单 ...

  3. js创建对象的三种方式

    <script> //创建对象的三种方式 // 1.利用对象字面量(传说中的大括号)创建对象 var obj1 = { uname: 'ash', age: 18, sex: " ...

  4. JS 创建对象的几种方式

    面向对象就是把属性和操作属性的方法放在一起作为一个相互依存的整体--对象,即拥有类的概念,基于类可以创建任意多个实例对象,一般具有封装.继承.多态的特性! ECMA-262把对象定义为:"无 ...

  5. JS创建对象的几种方式整理

    javascript是一种“基于prototype的面向对象语言“,与java有非常大的区别,无法通过类来创建对象.那么,既然是面象对象的,如何来创建对象呢? 一:通过“字面量”方式创建对象 方法:将 ...

  6. js创建对象的四种方式

    (1)对象字面量         var clock = { hour:12, minute: 10, second: 10, showTime: function(){ alert(this.hou ...

  7. js创建对象的几种方式 标签: javascript 2016-08-21 15:23 123人阅读 评论(0)

    1.传统方法,创建一个对象,然后给这个对象创建属性和方法. var person = new Object(); person.name = "张三"; person.age = ...

  8. js创建对象的6种方式总结

    1.new 操作符 + Object 创建对象 var person = new Object(); person.name = "lisi"; person.age = 21; ...

  9. js创建对象的6种方式

    一.工厂模式 function createStudent(name,age){ var o=new Object(); o.name=name; o.age=age; o.myName=functi ...

随机推荐

  1. 删除win7远程桌面历史记录

    开始-运行-“regedit”注册表中找到HKEY_CURRENT_USER\Software\Microsoft\Terminal Server Client\Default 删除不需要的即可

  2. s5pv210中断体系

    一.什么是中断? 1.中断的发明是用来解决宏观上的并行需要的.宏观就是从整体上来看,并行就是多件事情都完成了. 2.微观上的并行,就是指的真正的并行,就是精确到每一秒甚至每一刻,多个事情都是在同时进行 ...

  3. tablediff使用方法

    tablediff -sourceserver "db0093\sql2008" -sourcedatabase "testly" -sourcetable & ...

  4. IOS系列swift语言之课时六

    这节课需要讲的就是协议,方法,委托模式(依赖倒转) 代码刷起中...... // // main.swift // ExAndProtocol // // Created by David on 23 ...

  5. CC1310电源管脚

    对于48pin脚的CC1310而言,属于电源类的管脚如下: 上述电源类管脚的关系如下: 1 VDDS类管脚 VDDS类管脚包括VDDS.VDDS2.VDDS3和VDDS_DCDC四个管脚.其中VDDS ...

  6. (转)myeclipse插件—SVN分支与合并详解【图】

    svn作为版本控制软件被广泛用于众多公司的开发团队中,最多的场景就是一个项目上传svn后,一个组内的小伙伴在上边提交和更新代码以及解决冲突,其实这只是发挥了svn的很小的一部分功能. 先稍微介绍一下s ...

  7. 一个简单xml数据转换为数组的方法

    本人用easywechat做微信回复图文,从数据库中拿到的数据直接是xml拼好的数据,但是框架只有自带的获取xml格式的语句,所有需要将xml数据中所需要的数据拿出来用来拼接. 搜了好多资料说的都很麻 ...

  8. 转载:shell脚本之sed使用----替换、变量、转义字符

    sed替换的基本语法为:----s后面跟的是分隔符,原字符串可使用.*这种正则表达式进行整行替换 代码如下: sed 's/原字符串/替换字符串/' 单引号里面,s表示替换,三根斜线中间是替换的样式, ...

  9. mouseChildren启示

    将aSprite的 mouseChildren 属性设置为 false ,可以实现mouseClick 事件的目标为 aSprite对象,而不是其子对象中的任一个.

  10. Spring环境搭建之:导入jar包、配置文件名称及放置位置

    Spring环境搭建之:导入jar包.配置文件名称及放置位置 现在项目开发中spring框架应用的还是比较多的,自己用的还不太熟练,每次用的时候总配置半天,总有些配置弄错,就找个时间总结以下,方便以后 ...