// 1. 原型方式
function PCar(){
}
PCar.prototype.color = "blue";
var pcar1 = new PCar();
/*
调用 new Car()时,原型的所有属性都被立即赋予要创建的对象,意味着所有的 PCar 实例存放的是指向
showColor() 函数的指针,从语义看起来都属于一个对象,因此解决了前面两种方式存在的问题。此外使用
该方法,还能使用 instanceof 运算符检查给定变量指向的对象类型。因此下面的代码将输出 true:
*/
alert(pcar1 instanceof PCar); // output "true"
/*
这个方法看起来不错,遗憾的是,它并不尽人意。
1. 首先这个构造函数没有参数。使用原型方式时,不能给构造函数传递参数初始化属性值,因为 pcar1 和
pcar2 的属性都等于 "blue"
2. 真正的问题出现在属性指向的对象,而不是函数时,函数共享不会造成任何问题,但是对象却是很少被多个
实例共享的。
*/
// 2. 混合的构造函数/原型方式(推荐)
/*
联合使用构造函数和原型方式,就可像使用其他程序设计语言一样创建对象,这种概念非常简单,即用构造函数
定义对象的所有非函数属性,用原型方式定义对象的函数属性(方法)。
*/
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');
alert(hcar1.drivers); // output "Mike,Sue,Matt"
alert(hcar2.drivers); // output "Mike,Sue"
// 3. 动态原型方式 (推荐)
/*
对于习惯使用其他开发语言的开发者来说,使用混合构造函数/原型方式感觉不那么和谐。批评构造函数/原型方式的人
认为,在构造函数内找属性,在外部找方法的做法不合理。所以他们设计了动态原型方式,以供更友好的编码风格。
动态原型方式的基本想法与混合构造函数/原型方式 相同,即在构造函数内定义非函数的属性,而函数的属性则利用
原型属性定义。唯一的区别是赋予对象方法的位置。下面是使用动态原型方法重写的 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();
alert(DCar._initialized); // output "true"
alert(dcar1._initialized); // output "undefined"
//4、对象直接量、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
};
var a = new Array(); // Create an empty array
var d = new Date(); // Create an object representing the current date and time
var r = new RegExp("javascript", "i"); // Create a pattern-matching object
创建对象后,我们可以通过"."运算符,在对象中创建新属性、引用已有属性、设置属性值等。
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;
分享到:
相关推荐
NULL 博文链接:https://redhacker.iteye.com/blog/1457293
NULL 博文链接:https://redhacker.iteye.com/blog/1457020
详解js创建对象的几种方式和对象方法 这篇文章是看js红宝书第8章,记的关于对象的笔记(第二篇)。 创建对象的几种模式: 工厂是函数的意思。工厂模式核心是定义一个返回全新对象的函数。 function getObj...
javascript创建对象、对象继承的有用方式详解_.docx
本文详细讲解如何在js中创建类和对象,包括各种创建对象的方法,以及各种方法的优略
1.new Object() 2.字面量创建对象 构造函数创建对象 工厂模式
本文为大家分享了js创建对象的多种方法,分享个方法的优劣,具体内容如下 第一种创建对象的方式: 创建JSON对象 推荐使用的场合: 作为函数的参数,临时只用一次的场景。比如设置函数原型对象。 var object = { ...
NULL 博文链接:https://redhacker.iteye.com/blog/1458580
NULL 博文链接:https://kejiangwei.iteye.com/blog/429632
js中对象的创建有多种方式,下面就是我整理的几种创建方式。希望对你有所帮助
NULL 博文链接:https://yueyemaitian.iteye.com/blog/781915
方便学习js类的朋友,让你快速的掌握js类的定义方法,方法有很多种,结果都一样。大家可以根据自己的爱好选用。
本文介绍了几种js创建对象的方法,分享给大家供大家参考,具体内容如下 1、工厂模式 弊端:没有解决对象的识别问题,即怎么知道一个对象的类型。 2、构造函数模式 与工厂模式相比: 1、没有显式的创建对象 2...
js对象创建,事件委托测试,this apply call
js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式).docx
本篇文章主要介绍了JavaScript创建对象的多种方式以及优缺点,主要介绍了5种方式,有兴趣的可以了解下
JS是基于对象的语言,可以使用面向对象思想模拟JAVA|C++之类的面向对象语言。...javascript创建对象 一、直接创建 //直接创建 //JS创建对象 //1:创建空对象 var person1 = new Object(); //2
本文实例讲述了JavaScript创建对象的常用方式。分享给大家供大家参考,具体如下: JS中没有类的概念,那么怎么创建对象呢?下面一一来细说! 传统的创建对象的方式: 1、创建Object的实例 var person = new Object...
本篇博客目的在于给大家分享一下JS中如何去创建对象,以及创建对象的方法,让大家以后可以使用JS快乐的创建对象,以及在合适的场景使用合适的方式创建对象。 JS中的对象概念: 在JS中,我们把对象定义为:“无序属性...