[转载]javascript创建对象的几种方式
原文链接:http://qingfeng825.iteye.com/blog/1935648
1. 工厂方法:能创建并返回特定类型对象的工厂函数(factory function).
function createCar(sColor) {
    // 或者 var car = new Object;
    var car = new Object();
    // 对象属性
    car.color = sColor;
    // 对象方法
    car.showColor = function() {
        alert(123);
    };
    // 记住,这里一定要用;表示结束
// 这里是 return car;而不是 return this.car;因为 this.car 为 undefined
    return car;
}
// 调用此函数时,将创建对象,并赋予它所有必要的属性,使用此方法创建car对象的两个版本(oCar1和oCar2),他们的属性完全一样。
// 使用此方法存在的问题:
// 1.语义上看起来不像使用带有构造函数的new运算那么正规.
// 2.使用这种方式必须创建对象的方法。每次调用createCar(),都要创建showColor(),
// 意味着每一个对象都有自己的showColor版本,事实上,每一个对象都共享了是同一个函数.
// 有些开发者在工厂函数外定义对象的方法,然后通过属性指向该方法。从而避免这个问题:
function createCar2(sColor) {
    var car = new Object();
    car.color = sColor;
    car.showColor = showColor;
    return car;
}
function showColor() {
    alert(this.color);
}
var oCar1 = createCar('red');
var oCar2 = createCar('yellow');
var oCar3 = createCar2('blue');
var oCar4 = createCar2('black');
// 注意这两个对象(oCar3 和 oCar4)调用showColor 属性的方式,虽然美其名曰是“属性”,其实还是方法!!!
// 所以是oCar3.showColor();而不是 oCar3.showColor;
oCar3.showColor();
oCar4.showColor();
// 在这段重写的代码中,在函数createCar2()前定义了函数showColor(),
// 在createCar2()内部,赋予对象一个已经指向已经存在的showColor()函数的指针,
// 从功能上讲,这样解决了重复创建对象的问题,但该函数看起来不像对象的方法。
// 所有这些问题引起了开发者的定义构造函数的出现
2. 构造函数方式
function Car(sColor) {
    this.color = sColor;
    this.showColor = function() {
        alert(this.color);
    };
}
var car1 = new Car('red');
car1.showColor();
// 你可能已经注意到第一个的差别了,在构造函数内部无创建对象,而是使用this关键字,
// 使用new运算符调用构造函数,在执行第一行代码前先创建一个对象,只有用this才能访问该对象。
// 然后可以直接赋予this属性,默认情况下是构造函数的返回值,(不必明确使用return运算符)。
// 这种方式在管理函数方面与工厂方法一样都存在相同的问题.
3. 原型方式
function PCar() {
}
PCar.prototype.color = "blue";
var pcar1 = new PCar();
// 调用newCar()时,原型的所有属性都被立即赋予要创建的对象,意味着所有的PCar实例存放的是指向showColor()函数的指针,
// 从语义看起来都属于一个对象,因此解决了前面两种方式存在的问题。
// 此外使用该方法,还能使用instanceof运算符检查给定变量指向的对象类型。
// 因此下面的代码将输出true:
// output "true"
alert(pcar1 instanceof PCar);
// 这个方法看起来不错,遗憾的是,它并不尽人意。
// 1.首先这个构造函数没有参数。使用原型方式时,不能给构造函数传递参数初始化属性值,因为pcar1和pcar2的属性都等于"blue"
// 2.真正的问题出现在属性指向的对象,而不是函数时,函数共享不会造成任何问题,但是对象却是很少被多个实例共享的。
4. 混合的构造函数/原型方式(推荐)
// 联合使用构造函数和原型方式,就可像使用其他程序设计语言一样创建对象,
// 这种概念非常简单,即用构造函数定义对象的所有非函数属性,用原型方式定义对象的函数属性(方法)。
function hCar(sColor) {
    this.color = sColor;
    this.drivers = new Array('Mike', 'Sue');
}
hCar.prototype.showColor = function() {
    alert(this.color);
}
var hcar1 = new hCar('y color');
var hcar2 = new hCar('r color');
hcar1.drivers.push('Matt');
// output "Mike,Sue,Matt"
alert(hcar1.drivers);
// output "Mike,Sue"
alert(hcar2.drivers);
5. 动态原型方式(推荐)
// 对于习惯使用其他开发语言的开发者来说,使用混合构造函数/原型方式感觉不那么和谐。
// 批评构造函数/原型方式的人认为,在构造函数内找属性,在外部找方法的做法不合理。
// 所以他们设计了动态原型方式,以供更友好的编码风格。
// 动态原型方式的基本想法与混合构造函数/原型方式相同,即在构造函数内定义非函数的属性,
// 而函数的属性则利用原型属性定义。
// 唯一的区别是赋予对象方法的位置。
// 下面是使用动态原型方法重写的Car类:
function DCar(sColor) {
    this.color = sColor;
    this.drivers = new Array('Mike', 'Sue');
if (typeof DCar._initialized == 'undefined') {
DCar.prototype.showColor = function() {
            alert(this.color);
        }
    }
DCar._initialized = true;
}
var dcar1 = new DCar('y dcar');
var dcar2 = new DCar('b dcar');
dcar1.showColor();
dcar2.showColor();
// output "true"
alert(DCar._initialized);
// output "undefined"
alert(dcar1._initialized);
6、对象直接量、new创建
// 创建对象最简单的方法是你的javascript代码中包含对象直接量,也可以通过运算符new创建。
var empty = {};// An object with no properties
var point = {
    x : 0,
    y : 0
};
var circle = {
    x : point.x,
    y : point.y + 1,
    radius : 2
};
var homer = {
    "name" : "Homer Simpson",
    "age" : 34,
    "married" : true,
    "occupation" : "plant operator",
    'email' : 'homer@example.com'
};
// Create an empty array
var a = new Array();
// Create an object representing the current date and time
var d = new Date();
// Create a pattern-matching object
var r = new RegExp("javascript", "i");
// 创建对象后,我们可以通过"."运算符,在对象中创建新属性、引用已有属性、设置属性值等。
// 创建对象
var book = new Object();
book.title = "JavaScript: The Definitive Guide";
// 作为对象属性的,嵌套对象
book.chapter1 = new Object();
book.chapter1.title = "Introduction to JavaScript";
book.chapter1.pages = 11;
book.chapter2 = {
    title : "Lexical Structure",
    pages : 6
};
// 从对象中读取一些属性.
alert("Outline: " + book.title + "\n\t" + "Chapter 1 " + book.chapter1.title
        + "\n\t" + "Chapter 2 " + book.chapter2.title);
// 在上例中,需注意,可以通过把一个值赋给对象的一个新属性来创建它.
// 在JavaScript语句中提到过用for/in语句可以遍历对象的属性和方法。
// 删除属性:
delete book.chapter2;
[转载]javascript创建对象的几种方式的更多相关文章
- JavaScript 创建对象的七种方式
		
转自:xxxgitone.github.io/2017/06/10/JavaScript创建对象的七种方式/ JavaScript创建对象的方式有很多,通过Object构造函数或对象字面量的方式也可以 ...
 - JavaScript创建对象的几种 方式
		
//JavaScript创建对象的七种方式 //https://xxxgitone.github.io/2017/06/10/JavaScript%E5%88%9B%E5%BB%BA%E5%AF%B9 ...
 - javascript创建对象的几种方式
		
javascript创建对象简单的说,无非就是使用内置对象或各种自定义对象,当然还可以用JSON:但写法有很多种,也能混合使用.主要为下面几种:1.对象字面量的方式 person={firstname ...
 - JavaScript创建对象的6种方式
		
JavaScript创建对象简单的说,无非就是使用内置对象(Object)或各种自定义对象,当然还可以用JSON,但写法有很多种,也能混合使用. 1.对象字面量的方式 person = {name : ...
 - javascript创建对象的几种方式?
		
javascript创建对象简单的说,无非就是使用内置对象或各种自定义对象,当然还可以用JSON:但写法有很多种,也能混合使用. 1.对象字面量的方式 person={ firstname:" ...
 - JavaScript创建对象的几种方式总结
		
ECMA把对象定义为:无序属性的集合,其属性可以包含基本值.对象或者函数. 1. 使用Object构造函数创建对象 创建自定义对象的最简单的方式就是创建一个Object的实例,然后再为它添加属性和方法 ...
 - javascript 创建对象的几种方式
		
1. //基于已有对象扩充其属性和方法var object = new Object(); object.name = "zhangsan"; object.sayName = f ...
 - Javascript 创建对象的三种方式
		
function createPerson(name, qq) //工厂方式 { //在工厂里创建个对象 var obj=new Object(); obj.name=name; obj.qq=qq; ...
 - javascript创建对象的7种方式
		
/*1.工厂模式*/ function createPerson(name,age,job) { var o = new object(); o.name = name; o.age = age; o ...
 
随机推荐
- WSADATA
			
中文名 WSADATA 操作系统 Windows CE 版本: 大于等于1.0 定义位置: Winsock.h 目录 1 说明 2 结构原型 3 参数说明 4 备注 说明编辑 WSADATA结构被用来 ...
 - Centos 6.0将光盘作为yum源的设置方法
			
在使用Centos 的时候,用yum来安装软件包是再方便不过了,但是如果在无法连接互联网的情况下,yum就不好用了. 下面介绍一种方式,就是将Centos安装光盘作为yum源,然后使用yum来安装软件 ...
 - easyUI datagrid view扩展
			
//扩展easyuidatagrid无数据时显示界面 var emptyView = $.extend({}, $.fn.datagrid.defaults.view, { onAfterRender ...
 - Construct Bounding Sphere
			
点集的包围球 http://en.wikipedia.org/wiki/Bounding_sphere http://blogs.agi.com/insight3d/index.php/2008/02 ...
 - thinkphp新增
			
$m = M('content'); //与 $m = new Model('content')效果一样 $date = array( 'username' => I('username', ...
 - RL中“#” “?” &“”号的作用
			
阅读目录 1. # 2. ? 3. & 回到顶部 1. # 10年9月,twitter改版.一个显著变化,就是URL加入了"#!"符号.比如,改版前的用户主页网址为http ...
 - Yii2.0-生成二维码实例
			
原文地址:http://www.yii-china.com/post/detail/19.html
 - ps切图设置
			
1. 新建设置 文件->新建->预设->自定义 1920 像素 2000 像素 72 像素/英寸 背景内容 透明 存储预设 2.视图设置 视图->显示->智能参考线选中视 ...
 - .NET安全审核检查表
			
书籍名称:Web安全设计之道 -.NET代码安全,界面漏洞防范与程序优化 .NET安全审核检查表 检查项 任务描述 设计环节 Security descisions should no ...
 - 常用的MIME类型
			
.doc application/msword .docx application/vnd.openxmlformats-officedocument.wordprocessingml.d ...