DOMxpath を使用して、テキスト ノードが空の HTML タグを削除しますが、<br/>
タグは保持します。
$xpath = new DOMXPath($dom);
while(($nodeList = $xpath->query('//*[not(text()) and not(node()) and not(self::br)]')) && $nodeList->length > 0)
{
foreach ($nodeList as $node)
{
$node->parentNode->removeChild($node);
}
}
別の問題に遭遇するまでは完全に機能しますが、
$content = '<p><br/><br/><br/><br/></p>';
この種の厄介な問題をどのように削除し<br/>
ます<p>
か? <br/>
つまり、単独では許可したくありませんが、このような適切なテキストのみ<p>
を許可します。<br/>
$content = '<p>first break <br/> second break <br/> the last line</p>';
それは可能ですか?
それとも正規表現の方がいいですか?
私はこのようなものを試しました、
$nodeList = $xpath->query("//p[text()=<br\s*\/?>\s*]");
foreach($nodeList as $node)
{
$node->parentNode->removeChild($node);
}
しかし、それはこのエラーを返します、
Warning: DOMXPath::query() [domxpath.query]: Invalid expression in...