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();
    

      

  • 相关阅读:
    VS2019添加引用,对COM组件的调用错误
    ArcPy批量选择指定属性的要素
    使用ArcMap批量处理线悬挂问题
    Springboot 允许跨域的方法
    博客搬至CSDN
    Java项目中修复Apache Shiro 默认密钥致命令执行漏洞(CVE-2016-4437)详细说明
    ES index type 概述
    为什么有些人钱花了而赚不到钱呢?
    后台管理系统模板
    resolv.conf search openstacklocal novalocal
  • 原文地址:https://www.cnblogs.com/yxhblogs/p/7189963.html
Copyright © 2011-2022 走看看