这篇文章主要讲解了如何使用javascript中的解释器模式,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
介绍:之前在做java开发时,数据库的增删改查特别频繁,并且场景不同需要用到的SQL语句页都不同,如何用调用方法的形式来使用sql语句,拼接sql?这就是这一节我们要讲的解释器模式。
定义:定义一个语言的文法,并且建立一个解释器来解释该语言中的句子,这里的语言是指使用规定格式和语法的代码。解释器模式是一种类行为型模式。
场景:我们实现一个解释器,用来判断传递的数字是奇数还是偶数,是正数还是负数,是正奇数还是负奇数。
示例:
var TerminalExpression = function(data){ this.data = data; this.interpret = function(context){ if(context === this.data){ return true; } return false; } } var OrExpression = function(exprArr){ this.exprArr = exprArr; this.interpret = function(context){ var isMatch = false; this.exprArr.map(function(item){ if(item.interpret(context)){ isMatch = true; } }) return isMatch; } } var AndExpression = function(exprArr){ this.exprArr = exprArr; this.interpret = function(context){ var isMatch = true; this.exprArr.map(function(item){ if(!item.interpret(context)){ isMatch = false; } }) return isMatch; } } function getEvenExpression(){ var ExpressionList = []; for(var i = -10; i<100; i++){ if(i % 2 == 0){ ExpressionList.push(new TerminalExpression(i)); } } return new OrExpression(ExpressionList); } function getOddExpression(){ var ExpressionList = []; for(var i = -10; i<100; i++){ if(i % 2 != 0){ ExpressionList.push(new TerminalExpression(i)); } } return new OrExpression(ExpressionList); } function getNegativeOddExpression(){ var ExpressionList = []; for(var i = -10; i<100; i++){ if(i < 0){ ExpressionList.push(new TerminalExpression(i)); } } return new OrExpression(ExpressionList); } var isEven = getEvenExpression(); var isOdd = getOddExpression(); var isNegative = getNegativeOddExpression(); var isNegativeAndOdd = new AndExpression([isNegative,isOdd]); console.log('2是偶数吗? ' + isEven.interpret(2));//2是偶数吗? true console.log('3是偶数吗? ' + isEven.interpret(3));//3是偶数吗? false console.log('3是奇数吗? ' + isOdd.interpret(3));//3是奇数吗? true console.log('3是负数吗? ' + isNegative.interpret(3));//3是负数吗? false console.log('-3是负数吗? ' + isNegative.interpret(-3));//-3是负数吗? true console.log('-3是负奇数吗? ' + isNegativeAndOdd.interpret(-3));//-3是负奇数吗? true console.log('-4是负奇数吗? ' + isNegativeAndOdd.interpret(-4));//-4是负奇数吗? false console.log('3是负奇数吗? ' + isNegativeAndOdd.interpret(3));//3是负奇数吗? false
文章标题:如何使用javascript中的解释器模式-创新互联
文章路径:https://www.cdcxhl.com/article30/cocjpo.html
成都网站建设公司_创新互联,为您提供静态网站、网站设计公司、网站维护、网站营销、做网站、电子商务
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联