Я использую 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...