js面向对象-创建对象

本文深入解析了工厂模式和构造函数模式在JavaScript中的应用,包括如何通过创建对象、添加属性和方法以及最终返回对象的过程。同时,文章还探讨了构造函数方式与原型方式的结合使用,以及它们在实际开发中的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工厂模式

工厂模式通过在函数中创建一个对象(原材料),然后通过给这个对象添加属性和方法(加工),最后返回这个对象(出厂)。

// 1.工厂模式
function createPerson(name,age,job) {
	//1.原材料
	var o = new Object(); 
	//2.加工 
	o.name = name;
	o.age = age;
	o.job = job;
	o.sayName = function() {
		alert(this.name);
	};

	//3.出厂
	return o;
}
var yoomin = createPerson('yoomin',24,'programmer');  // 调用,没有new

  构造函数模式

构造函数是通过给this添加属性和方法,在new的时候才返回一个对象,构造函数本身是没有返回值的。

// 2.构造函数模式
function Person(name,age,job) {
	this.name = name;
	this.age = age;
	this.job = job;
	this.sayAge = function() {
		alert(this.age);
	}
}
var Jay = new Person('Jay',30,'singer');  //调用

 

构造函数方式与原型方式组合

使用构造函数方式定义属性,用原型方式定义方法和共享变量:

构造函数定义属性:

function Person(name,age,job) {
	// 构造函数模式定义实例属性
	this.name = name;
	this.age = age;
	this.job = job;
}

  原型方式定义方法:

Person.prototype = {
	//原型模式定义方法和共享属性
	constructor: Person,  //重写原型改变了constructor,修正回来
	sayName:function() {
		alert(this.name);
	},
	sayJob:function() {
		alert(this.job);
	}
}

  注意:用字面量方式定义prototype,会改变prototype的constructor指向,需要修正。

创建对象:

var Kelly = new Person('Kelly',35,'singer');  //调用
Kelly.sayName();  //Kelly

  

转载于:https://www.cnblogs.com/yoomin/p/3932976.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值