首页 >web前端 >js教程 >JavaScript强化教程——正则表达式回溯

JavaScript强化教程——正则表达式回溯

巴扎黑
巴扎黑原创
2016-11-25 15:20:521112浏览

本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 —— 正则表达式回溯 

下面的例子演示了处理正则表达式分之的过程: 

    /h(ello|appy) hippo/.test("hello there,happy hippo"); 
这个正则表达式 "hello hippo"或"happy hippo".匹配过程开始时,首先会查找一个h,目标字符串的首字母恰好是h,于是立刻被找到。接下来,子表达式(ello|appy)提供了两个处理选项,正则表达式选择最左侧的选项(分之选择总是从左向右进行),检查ello是否匹配字符串中的下一个字符,匹配成功,正则表达式进行匹配随后的空格,由于hippo中的h无法匹配下一个字符串中的t,因此匹配无法继续。此时,正则表达式还不能放弃,因为它还未城市完所有的可选项,随后他会回溯到最近的决策点(匹配万首字符h后面的位置)并尝试匹配第二个分支。匹配并没有成功,也没有更多的可选项,所以正则表达式认为从字符串的第一个字符匹配是不能成功的,因此从第二个字符开始重新尝试。他没有找到h,于是继续搜索知道在第14个字符串的位置匹配到“happy”中的h,然后会再次进入分支过程,这次未能匹配ello,但是在回溯并尝试第二个分支过程后,匹配到了整个字符串“happy hippo”。 
匹配成功。 

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn