JavaScript学习之接口

鸭式辨型法实现JavaScript接口:

//ya shi bian li 法实现接口
			//接口检验,要能够检验是否实现个接口,及接口中所有的方法

			//定义接口对象
			var Interface = function(interfacename,methodArray){
				if(arguments.length < 2){
					throw new Error('the instance of interface constructor must be 2 length');
				}
				this.name = interfacename;
				this.methods = [];
				var length = methodArray.length;
				for(var i = 0 ; i < length; i ++){
					if(typeof methodArray[i] != 'string'){
						throw new Error('the Interface method name is error!');
					}
					this.methods.push(methodArray[i]);
				}
			}

			//声明接口实例
			var CompositInterface = new Interface("CompositInterface",["add","edit"]); 
			var FormItemInterface = new Interface("FormItemInterface",["delete","select"]);

			//定义实现类,实现这两个接口
			var InterfaceImp = function(){

			}
			InterfaceImp.prototype.add = function(){

			}
			InterfaceImp.prototype.edit = function(){
				
			}
			InterfaceImp.prototype.delete = function(){
				
			}
			// IntefaceImp.prototype.select = function(){
				
			// }

			//检验接口实例是否实现 接口的所有方法
			Interface.ensureImplements = function(object){
				if(arguments.length < 2){
					throw new Error("接口检验的方法,参数不能少于2");
				}
				for(var i = 1; i < arguments.length; i++){
					var tmpInterface = arguments[i];
					for(var j = 0, length = tmpInterface.methods.length; j < length; j++){
						var methodName = tmpInterface.methods[j];
						if(!object[methodName] || typeof object[methodName] != 'function'){
							throw new Error(object.constructor.name + "没有实现接口" + tmpInterface.name +"的方法" + methodName);
						}
					}
				}
				return true;
			}
			var instance = new InterfaceImp();
			Interface.ensureImplements(instance,CompositInterface,FormItemInterface);
			instance.add();


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于学习JavaScript的路线,我可以给你一些建议。以下是一个基本的学习路线: 1. 学习基本的HTML和CSS:在学习JavaScript之前,了解HTML和CSS的基础知识是很重要的,因为它们是构建网页的基石。 2. 学习JavaScript基础:开始学习JavaScript语言本身,包括变量、数据类型、运算符、条件语句、循环等基本概念。 3. 掌握DOM操作:DOM(Document Object Model)是JavaScript操作网页元素的接口学习如何使用JavaScript来操作HTML元素、修改内容、添加事件等。 4. 学习JavaScript函数和面向对象编程:深入学习JavaScript函数的概念、如何定义和调用函数,以及面向对象编程的基本概念。 5. 学习AJAX和异步编程:了解如何使用JavaScript进行异步操作,包括AJAX请求、处理响应等。 6. 学习常用的JavaScript库和框架:掌握一些常用的JavaScript库和框架,如jQuery、React、Vue等,可以提高开发效率。 7. 实践项目:通过实践项目来巩固所学知识,可以选择一些小型的项目来开始,逐渐增加复杂度。 8. 持续学习和实践:JavaScript是一个不断发展的语言,持续学习新的特性和技术,参与开源项目和社区讨论,可以不断提升自己的技能。 这只是一个基本的学习路线,你可以根据自己的兴趣和需求进行调整和扩展。同时,多阅读相关的文档、教程和参考资料,多动手实践是提高编程能力的关键。祝你学习愉快!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值