面向对象--构造函数

一、生成实例对象的原始模式

var cat = {
		name: '',
		color: ''
	}

	var cat1 = {};
	cat1.name ='大毛';
	cat1.color = '黄色';

	var cat2 = {};
	cat2.name = '二毛';
	cat2.color = '黑色';

二、解决代码重复 写一个函数

function Cat (name, color){
		return {
			name: name,
			color: color
		}
	}

	var Cat1 = Cat('三毛', '红色');
	var Cat2 = Cat('四毛', '绿色');

三、看不出同一个原型,用构造函数

function CatNew (name, color ){
		this.name = name;
		this.color = color;
	}
	var cat3 = new CatNew('六毛', '灰色');
	var cat4 = new CatNew('七毛', '白色');

注: 所有实例拥有相同属性和方法时,用prototype模式

  原因:每创建一个实例就需要重复一次代码,占用内存,降低性能 

未使用prototype:

function CatQ( name, color ){
		this.name = name;
		this.color = color;
		this.type = '猫科动物';
		this.eat = function () {
			console.log('吃老鼠');
		}
	}

	var cat5 = new CatQ('老五', '彩色');
	var cat6 = new CatQ('老六','黑白');

使用prototype:

function Catq (name, color) {
		this.name = name;
		this.color = color;
	}
	Catq.prototype.type = "我是猫科动物";
	Catq.prototype.eat = function () {
		console.log('我想吃老鼠');
	}

	var cat7 = new Catq('老七', '灰色');
	var cat8 = new Catq('老八',"白色");
	for(var prop in cat7) {
		console.log(prop);//属性的遍历
	}

使用prototyope模式:

所有实例对象的eat方法和type属性都是同一个内存地址   指向prototype 对象  

  

 

  

 

转载于:https://www.cnblogs.com/yigexiaojiangshi/p/7404871.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值