浏览 3186 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2016-08-19
下面的例子演示了处理正则表达式分之的过程: /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”。 匹配成功。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |