繁体   English   中英

使用简单的HTML DOM解析器删除空白标签

[英]Remove blank tags with simple HTML DOM parser

我有一个HTML输入,其中包含许多空白的强标签。 所以我想从html中删除这些空白的强标签。我使用了简单的HTML DOM,但是它不起作用

foreach($html->find('strong') as $strong)
{

    if(trim($strong->innertext) == '')
    {
        echo 'blank strong';
    }
}

在上面的代码中,我检查了if条件是否没有修剪功能,但仍然没有成功。 如何从HTML代码中删除空白标签或仅包含空格的标签?

您没有给出示例,但是可以说您具有此标记,可以使用outertext (顺便说一句,我在手册上也找不到某种removeChild() )。

$html_string = '
<div class="container">
<strong>Text1</strong>
<strong>Text2</strong>
<strong>Text3</strong>
<strong></strong>
<strong>Text5</strong>
</div>
';

$html = str_get_html($html_string);
foreach($html->find('strong') as $element) {
    if(trim($element->innertext) == '') {
        $element->outertext = '';
    }
}

echo htmlentities($html);

应该输出:

<div class="container"> <strong>Text1</strong> <strong>Text2</strong> <strong>Text3</strong> <strong>Text5</strong> </div>

第四个<strong></strong>标记现在应该消失了。

您可以只使用jquery删除空白标签。

$(document).ready(function(){
    $('strong').each(function(){
        if($.trim($(this).html()) == ''){
            $(this).remove();
        }
    })
})

您也可以使用preg_replace删除空的html标签。

$html = "abc<strong></strong><p>dd</p><b>non-empty</b><strong>  ashish </strong><strong><a>click</a></strong><strong>   </strong><strong>test</strong>"; 
$pattern = "/<[^\/>]*>([\s]?)*<\/[^>]*>/"; // pattern for removing all empty tags
echo preg_replace($pattern, '', $html);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM