我正在使用正則表達式來替換 p 標簽,如果有 p 標簽沒有屬性的 html 屬性和正則表達式是:$html = preg_replace("/<p[^>]*>(.+?)<\/p>/i", "<p>$1</p>", $html);如果 p 標簽沒有任何新行,則正則表達式運行良好<p style="text-align: center;">It is a long established fact that a reader will be distracted by the readable content of a page when looking at its layout</p>但是當 p 標簽有新行時,上面的正則表達式不起作用。舉個例子<p style="text-align: center;">It is a long established fact that a reader will bedistracted by the readable <br />content of a page when looking at its layou</p>那么有人可以建議在上面的正則表達式中需要進行哪些更改,以便如果 p 標簽具有包含新行的字符串,它們可以正常工作?
2 回答

瀟瀟雨雨
TA貢獻1833條經驗 獲得超4個贊
要使用 DOM 解析器,使用 DOMDocument 和loadHTML().
這會加載文檔,然后用于getElementsByTagName()選擇所有<p>標簽。然后對于它找到的每個標簽,它檢查它是否具有屬性并在需要時刪除它們......
$doc = new DOMDocument();
$doc->loadHTML($html);
$pTags = $doc->getElementsByTagName("p");
foreach ( $pTags as $p ) {
if ( $p->hasAttributes() ) {
foreach ( $p->attributes as $attribute ) {
$p->removeAttribute($attribute->nodeName );
}
}
}
// Save/echo the resultant HTML
echo $doc->saveHTML();
- 2 回答
- 0 關注
- 183 瀏覽
添加回答
舉報
0/150
提交
取消