JavaScript中两个字符串的匹配

工作中遇到一个问题,两个字符串匹配,要求:每个字符串中最多含有一个*,?可以无限多个

*代表一个任意长度的字符串,而?则代表一个字符

要求可以提示出两个冲突

代码如下:

用JavaScript实现代码如下:

str2XPosition?str2XPosition:str1XPosition;//success if(position!=0) { var patbeforeStr1 = str1.substring(0,position); var patbeforeStr2 = str2.substring(0,position); if(checkMarchQ(patbeforeStr1,patbeforeStr2)) { //alert(str1+'与'+str2+"前半部分冲突"); //然后对应后半部分进行测试 var str1XBackPosition = str1.length-str1XPosition-1; var str2XBackPosition = str2.length-str2XPosition-1; var backposition = str1XBackPosition>str2XBackPosition?str2XBackPosition:str1XBackPosition; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } } else { //alert(str1+'与'+str2+"前半部分冲突"); var str1XBackPosition = str1.length-str1XPosition-1; var str2XBackPosition = str2.length-str2XPosition-1; var backposition = str1XBackPosition>str2XBackPosition?str2XBackPosition:str1XBackPosition; if (backposition==0) { alert(str1+'与'+str2+"冲突"); } else { var patbackStr1 = str1.substring(str1.length-backposition,str1.length); var patbackStr2 = str2.substring(str2.length-backposition,str2.length); if(checkMarchQ(patbackStr1,patbackStr2)) { alert(str1+'与'+str2+"冲突"); } } } } else if((str1XPosition==-1 && str2XPosition!=-1)||(str1XPosition!=-1 && str2XPosition==-1))//有且只有一个字符串含有* { var strX = str1XPosition==-1?str2:str1;//含有*的字符串 var strNoX = str1XPosition==-1?str1:str2;//不含*的字符串 if (strX.length-1

其中*最起码为一个字符,以上程序并没有对输入的合法性进行验证

查看更多JavaScript的语法,大家可以关注:《》、《》,也希望大家多多支持编程之家。

相关文章

事件冒泡和事件捕获 起因:今天在封装一个bind函数的时候,发现el.addEventListener函数支持第三个参数...
js小数运算会出现精度问题 js number类型 JS 数字类型只有number类型,number类型相当于其他强类型语言...
什么是跨域 跨域 : 广义的跨域包含一下内容 : 1.资源跳转(链接跳转,重定向跳转,表单提交) 2.资源...
@ "TOC" 常见对base64的认知(不完全正确) 首先对base64常见的认知,也是须知的必须有...
搞懂:MVVM模式和Vue中的MVVM模式 MVVM MVVM : 的缩写,说都能直接说出来 :模型, :视图, :视图模...
首先我们需要一个html代码的框架如下: 我们的目的是实现ul中的内容进行横向的一点一点滚动。ul中的内容...