0

我正在寻找清理旧 HTML 表(使用 PHP)的最佳方法,以便它们是正确的 HTML5 表 - 这主要是剥离不允许的属性的问题。除此之外,我还想去除这些表格的内联样式。如果能一口气完成就太好了。

我一直在研究正则表达式,但是在阅读了不建议执行正则表达式之后,我正在寻找其他有用的东西。

4

1 回答 1

1

一个关于如何使用 DOMDocument 去除属性的快速示例 - 可以将其扩展为也添加属性,但这是另一回事。

$strhtml="
<table width='100%' cellpadding='10px' cellspacing='5px' border='2px'>
    <tr>
        <td align='left' valign='top'>banana</td>
    </tr>
</table>";

$remove=array('cellpadding','cellspacing','border','align','valign');


$dom=new DOMDocument;
$dom->loadHTML( $strhtml );

$elements=$dom->getElementsByTagName('*');
foreach( $elements as $node ){
    foreach( $remove as $attrib ){
        if( $node->hasAttribute( $attrib ) ){
            $node->removeAttribute( $attrib );
        }
    }
}

/* debug output */
echo '<textarea cols=100 rows=10>',$dom->saveHTML(),'</textarea>';
于 2016-09-15T08:19:28.387 回答