匹配任意字符的正則表達(dá)式寫法
更新時間:2010年04月29日 23:09:46 作者:
今天在寫一個小應(yīng)用的時候遇到個問題,原本是想捕捉到頁面中所有電驢地址,以便迅雷抓取。
實現(xiàn)代碼如下,起初測試正常(后來遇到問題),先來看最初的代碼
var docs = document.body.innerHTML;
var links =docs.match(/ed2k.*\|\//gi);//注意這里 使用了點(.)符號匹配任意字符
document.body.innerHTML = "";
for( var link in links){<BR>
document.body.innerHTML += links[link]+"<br/>"
}
以上代碼起初一切正常,在接下來的測試中發(fā)現(xiàn),如果電驢地址中存在全角字符時就匹配就會失敗。遂改用如下寫法
var docs = document.body.innerHTML;
var links =docs.match(/ed2k[\s\S]*?\|\//gi);//注意這里[\s\S]
document.body.innerHTML = "";
for( var link in links){
document.body.innerHTML += links[link]+"<br/>"
}
結(jié)論,點(.)符號在匹配任意字符時還是有局限性,具體規(guī)則不詳,暫且可用[\s\S]代之,同理[\d\D]或[\w\W]亦可。
復(fù)制代碼 代碼如下:
var docs = document.body.innerHTML;
var links =docs.match(/ed2k.*\|\//gi);//注意這里 使用了點(.)符號匹配任意字符
document.body.innerHTML = "";
for( var link in links){<BR>
document.body.innerHTML += links[link]+"<br/>"
}
以上代碼起初一切正常,在接下來的測試中發(fā)現(xiàn),如果電驢地址中存在全角字符時就匹配就會失敗。遂改用如下寫法
復(fù)制代碼 代碼如下:
var docs = document.body.innerHTML;
var links =docs.match(/ed2k[\s\S]*?\|\//gi);//注意這里[\s\S]
document.body.innerHTML = "";
for( var link in links){
document.body.innerHTML += links[link]+"<br/>"
}
結(jié)論,點(.)符號在匹配任意字符時還是有局限性,具體規(guī)則不詳,暫且可用[\s\S]代之,同理[\d\D]或[\w\W]亦可。
您可能感興趣的文章:
相關(guān)文章
在網(wǎng)頁中使用document.write時遭遇的奇怪問題
很多時候我們都會在網(wǎng)頁上的JavaScript中使用document.write來寫入一些東西,有的時候可能因為我們無法改變某一部分HTML而不得不使用這樣的辦法,也有的時候是因為在進(jìn)行跨應(yīng)用的腳本調(diào)用。2010-08-08
通過JS動態(tài)創(chuàng)建一個html DOM元素并顯示
需要通過點擊某個元素后, 動態(tài)創(chuàng)建一個DOM元素并顯示,因此寫了一些相關(guān)的js函數(shù),在此記錄下2014-10-10
javascript html 靜態(tài)頁面?zhèn)鲄?shù)
靜態(tài)頁面中用js獲取頁面參數(shù)的一些屬性方法,具體的獲取參數(shù),可以搜索本站以前的一些文章。2009-04-04

