我使用 DOMxpath 删除具有空文本节点但保留<br/>
标签的 html 标签,
$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...