javascript设计模式 – 解释器模式原理与用法实例分析
本文实例讲述了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
上面的例子中terminalexpression被称为终结符表达式类,封装底层的判断条件,一般解释器模式中只会存在少数几个终结符表达式类。
orexpression,andexpression称为非终结符表达式类,是基于多个终结符表达式组合而成相对复杂的逻辑。
解释器模式最核心的就是这两个类,基于他们可以扩展组合出丰富多样的条件。
虽然解释器模式的使用频率不是特别高,但是它在正则表达式,xml文档解释等领域还是得到了广泛的应用。
解释器模式总结:
优点:
* 易于扩展和修改文法规则。增加时只需要增加新的终结符表达式,符合开关原则。
缺点:
* 对于复杂文法难以维护,会充满非终结表达式。
* 执行效率低,由于使用了大量循环和递归调用,在解释复杂句子时速度很慢。
适用场景:
* 可以将一个需要解释执行的语言中的句子表示为一个抽象语法树
* 一些重复出现的问题可以用一种简单的语言来进行表达
* 一个语言文法较为简单
* 执行效率不是关键问题
感兴趣的朋友可以使用在线html/css/javascript代码运行工具:http://tools.jb51.net/code/htmljsrun测试上述代码运行效果。