zoukankan      html  css  js  c++  java
  • 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();
    

      

  • 相关阅读:
    碰到一个在app内部浏览器锚点异常的问题
    常用js方法
    preg_match_all正则表达式的基本使用
    无线路由器WDS 桥接设置方法
    链表和数组的区别在哪里?
    php报错: PHP Warning: PHP Startup: memcache: Unable to initialize module
    mysql修改密码
    快速排序
    vuex到底是个啥
    vue实现简单表格组件
  • 原文地址:https://www.cnblogs.com/yxhblogs/p/7189963.html
Copyright © 2011-2022 走看看