js原型与继承

Posted Yxh_blogs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js原型与继承相关的知识,希望对你有一定的参考价值。

var Beverage = function(){};

Beverage.prototype.boilWater = function(){
	console.log("把水煮沸");
};
Beverage.prototype.brew = function(){
	throw new Error("子类必须重写该方法");
};
Beverage.prototype.pourInCup = function(){
	throw new Error("子类必须重写该方法");
};
Beverage.prototype.addCondiments = function(){
	throw new Error("子类必须重写该方法");
};
Beverage.prototype.customerWantsCondiments = function(){
	return true;
};
Beverage.prototype.init = function(){
	this.boilWater();
	this.brew();
	this.pourInCup();
	if(this.customerWantsCondiments){
		this.addCondiments();
	}
};

var Coffee = function(){};
Coffee.prototype = new Beverage();//继承父类Beverage
Coffee.prototype.boilWater = function(){
	console.log("把水煮沸");
};
Coffee.prototype.brew = function(){
	console.log("用沸水冲泡咖啡");
};
Coffee.prototype.pourInCup = function(){
	console.log("把咖啡倒进杯子");
};
Coffee.prototype.addCondiments = function(){
	console.log("加糖和牛奶");
};

var Tea = function(){};
Tea.prototype = new Beverage();//继承父类Beverage
Tea.prototype.boilWater = function(){
	console.log("把水煮沸");
};
Tea.prototype.brew = function(){
	console.log("用沸水浸泡茶叶");
};
Tea.prototype.pourInCup = function(){
	console.log("把茶水倒进杯子");
};
Tea.prototype.addCondiments = function(){
	console.log("加入柠檬");
};
Tea.prototype.customerWantsCondiments = function(){
	return window.confirm("请问需要加调料吗?");
};

var coffee = new Coffee();//实例化Coffee
coffee.init();

var tea = new Tea();//实例化Tea
tea.init();

  

以上是关于js原型与继承的主要内容,如果未能解决你的问题,请参考以下文章

JS 类继承和原型继承区别

JS类的创建与继承

JS基础 原型与继承

js原型链和继承的理解

JS原型链与继承别再被问倒了

重操JS旧业第八弹:面向对象与继承