欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

正則表達(dá)式匹配閉合HTML標(biāo)簽的示例分析

小編給大家分享一下正則表達(dá)式匹配閉合HTML標(biāo)簽的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)公司主要從事成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)平順,十多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

任何復(fù)雜的正則表達(dá)式都是由簡單的子表達(dá)式組成的,要想寫出復(fù)雜的正則來,一方面需要有化繁為簡的功底,另外一方面,我們需要從正則引擎的角度去思考問題。關(guān)于正則引擎的原理,推薦《Mastering Regular Expression》中文名叫《精通正則表達(dá)式》。挺不錯的一本書。

OK,先確定我們要解決的問題——從一段Html文本中找出特定id的標(biāo)簽的innerHTML。

這里面最大的難點就是,Html標(biāo)簽是支持嵌套的,怎么能夠找到指定標(biāo)簽相對應(yīng)的閉合標(biāo)簽?zāi)兀?/p>

我們可以這樣想,先匹配最前面的起始標(biāo)簽,假設(shè)是div吧(<div),接著一旦遇到嵌套div,就“壓入堆?!?,后面如果遇到div閉合標(biāo)簽了,就“彈出堆棧”。如果遇到閉合標(biāo)簽的時候,堆棧里面已經(jīng)沒有東西了,那么匹配結(jié)束,此結(jié)束標(biāo)簽為正確的閉合標(biāo)簽。

我之所以能夠這樣去思考,是因為我了解過正則的特性,我知道正則中的平衡組能夠?qū)崿F(xiàn)我剛才說的“堆?!辈僮?。所以,如果我們要編寫復(fù)雜正則表達(dá)式,需要對正則的一些高級特性至少有所了解,這樣我們思考問題才有個方向。

匹配任意閉合HTML標(biāo)簽的正則表達(dá)式:

<(?<HtmlTag>[\w]+)[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>

如果只想匹配div標(biāo)簽,可以使用下面的正則表達(dá)式:

<(?<HtmlTag>div)[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>

是的,你可以把div修改成任意你想要匹配的HTML標(biāo)簽

如果想同時匹配多個HTML標(biāo)簽,可以使用下面的正則表達(dá)式:

<(?<HtmlTag>(div|span|h2))[^>]*?>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>

你還可以繼續(xù)添加更多要匹配的標(biāo)簽

如果想匹配包含ID的標(biāo)簽,可以使用下面的正則表達(dá)式:

<(?<HtmlTag>[\w]+)[^>]*\s[iI][dD]=(?<Quote>["']?)footer(?(Quote)\k<Quote>)[^>]*?(/>|>((?<Nested><\k<HtmlTag>[^>]*>)|</\k<HtmlTag>>(?<-Nested>)|.*?)*</\k<HtmlTag>>)

這個正則匹配任意id為footer的HTML標(biāo)簽

創(chuàng)新互聯(lián)小編補充:

正則 \k

你也可以自己指定子表達(dá)式的組名。要指定一個子表達(dá)式的組名,請使用這樣的語法:(?<Word>\w+)(或者把尖括號換成'也行:(?'Word'\w+)),這樣就把\w+的組名指定為Word了。要反向引用這個分組捕獲的內(nèi)容,你可以使用\k<Word>,所以上一個例子也可以寫成這樣:\b(?<Word>\w+)\b\s+\k<Word>\b。

有,但是是跟<>配合用的,詳見下面:
指定子表達(dá)式的組名。要指定一個子表達(dá)式的組名,請使用這樣的語法:(?<Word>\w+)(或者把尖括號換成'也行:(?'Word'\w+)),這樣就把\w+的組名指定為Word了。要反向引用這個分組捕獲的內(nèi)容,你可以使用\k<Word>,所以上一個例子也可以寫成這樣:\b(?<Word>\w+)\b\s+\k<Word>\b。

以上是“正則表達(dá)式匹配閉合HTML標(biāo)簽的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)站名稱:正則表達(dá)式匹配閉合HTML標(biāo)簽的示例分析
文章URL:http://aaarwkj.com/article42/gpjiec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、做網(wǎng)站網(wǎng)站收錄、品牌網(wǎng)站設(shè)計、搜索引擎優(yōu)化虛擬主機

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
亚洲欧美精品专区极品| 亚洲高清有码在线观看| 欧美精品日韩中文字幕在| 国产三级精品在线免费| 亚洲一区二区三区日本久久| 成人午夜激情福利动态| 开心激情欧美一区二区| 精品国产一区二区三区不卡| 国产精品传媒成人免费| 免费久久人人爽人人爽| 国产亚洲无线码一区二区 | 午夜影院在线免费观看三区| 中文字幕一区二区av| 国产精品岛国片在线观看| 扒开女性毛茸茸的视频| 国内精品免费视频不卡| 中文字幕午夜av福利| 国产午夜福利av在线麻豆| 麻豆人妻性色av专区| 国产自拍成人精品视频| 欧美日韩亚洲综合国产人| 色哟哟亚洲精品在线视频| 久久成人午夜免费电影| 亚洲中文字幕一区乱码| 国产精品自拍激情在线观看| 午夜日韩综合激情视频在线观看| 亚洲国产成人综合一区二区三区| 亚洲欧美日韩一区中文天国| 欧美精品一区二区毛卡片| 日韩伦理高清在线观看| 激情欧美一区二区三区精品| 国产无套内射三级视频| 亚洲欧美日韩校园春色| 十八禁在线观看点击进入| 亚州无吗一区二区三区| 伊人久久亚洲福利精品| 成人福利午夜一区二区| 亚洲一区精品二人人爽久久| 亚洲国产日韩一区二区在线| 久久最新最热视频精品| 玩弄丰满熟妇班主任老师 |