前言
在JS的正则零宽断言匹配中,只支持前瞻匹配,不支持后瞻。这就尴尬了,因为在业务当中,我们大多时候是知道了要目标数据的前后缀字符串,但是并不想连同前后缀一起获取。
为了模拟后瞻,我想,要不就用笨方法,先将前后缀字符串一同提取,然后再讲前后缀字符串一同replace为空字符串。于是就有了下面这个简单的方法,但确实很实用:
示例代码如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
// 提取固定字符之间的字符串
function getInnerString(source, prefix, postfix) {
var regexp = new RegExp(encodeReg(prefix) + '.+' + encodeReg(postfix), 'gi' );
var matches = String(source).match(regexp);
var formatedMatches = _.map(matches, value => {
return value
.replace(prefix, '' )
.replace(postfix, '' );
});
return formatedMatches;
}
//转义影响正则的字符
function encodeReg(source) {
return String(source).replace(/([.*+?^=!:${}()|[\]/\\])/g, '\\$1' );
}
|
使用:
1
2
3
4
5
|
var a = '让我们荡起双桨吧' ;
getInnerString(a, '让我们' , '吧' ); // ['双桨']
var b = '老总和不在办公室,有事请留言给李秘书' ;
getInnerString(b, '有事请留言给' , '' ); // ['李秘书']
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.dengzhr.com/js/1339