正則表達式中的反向預搜索(下)
更新時間:2009年12月14日 03:17:27 作者:
在前面正則表達式中的反向預搜索中,在JavaScript中利用RegExp對象實現(xiàn)了正則表達式反向預搜索的字符串替換功能。
代碼為:
復制代碼 代碼如下:
//程序目的,去掉圖片路徑中的域名
var str = '<img src="http://www.dbjr.com.cn/images/logo.gif">';
var reg1 = /(\<img)(.*(?=(http|https)\:\/\/))((http|https)\:\/\/[^\/]*)/gim;
str.match(reg1);
alert(str.replace(RegExp.$4,'');
這個用法在字符串中只有一個URL時,是適用的,但是如果字符串中包含多個域名,例如:
復制代碼 代碼如下:
var str = '<img src="http://www.dbjr.com.cn/images/logo.gif">腳本之家首頁的<a href="http://www.dbjr.com.cn">鏈接</a>';
程序運行后去掉的內容就是第二個域名即http://www.dbjr.com.cn。這是為什么呢?
仔細查看正則表達式會發(fā)現(xiàn),在使用"(\<img) "匹配了<img之后,使用“.*”匹配所有字符直到“http://”或者“https://”。請注意,正是“.*”導致了這個問題的出現(xiàn),這里的“.*”就是說,一直查找和匹配,盡可能的多匹配,直到最后一個限定符,也就是說術語中的貪婪(greedy)匹配。很自然,就想到了使用非貪婪的匹配解決這個問題。把正在表達式改為:
復制代碼 代碼如下:
//與貪婪匹配的差別就是多了一個問號“?”,貪婪".*",非貪婪".*?"
var reg1 = /(\<img)(.*?(?=(http|https)\:\/\/))((http|https)\:\/\/[^\/]*)/gim;
解決問題的方法很簡單,但是也說明平時工作存在的一個重要問題:程序測試不充分。
相關文章
javascript 獲取url參數(shù)的正則表達式(用來獲取某個參數(shù)值)
javascript 傳多個參數(shù)的正則表達式(用來獲取某個參數(shù)值) ,腳本之家之前發(fā)布通過函數(shù)獲取url參數(shù)的代碼不是正則表達式。2010-01-01JavaScript正則表達式驗證身份證號碼是否合法(兩種方法)
正則表達式(regular expression)是一個描述字符模式的對象。下面通過本篇文章給大家介紹js正則表達式驗證身份證號碼是否合法,需要的朋友可以參考下本篇文章2015-09-09