前言
在JS的正則零寬斷言匹配中,只支持前瞻匹配,不支持后瞻。這就尷尬了,因為在業務當中,我們大多時候是知道了要目標數據的前后綴字符串,但是并不想連同前后綴一起獲取。
為了模擬后瞻,我想,要不就用笨方法,先將前后綴字符串一同提取,然后再講前后綴字符串一同replace為空字符串。于是就有了下面這個簡單的方法,但確實很實用:
示例代碼如下
// 提取固定字符之間的字符串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');}
使用:
var a = '讓我們蕩起雙槳吧';getInnerString(a, '讓我們', '吧'); // ['雙槳']var b = '老總和不在辦公室,有事請留言給李秘書';getInnerString(b, '有事請留言給', ''); // ['李秘書']
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答