我正在寻找清理旧 HTML 表(使用 PHP)的最佳方法,以便它们是正确的 HTML5 表 - 这主要是剥离不允许的属性的问题。除此之外,我还想去除这些表格的内联样式。如果能一口气完成就太好了。
我一直在研究正则表达式,但是在阅读了不建议执行正则表达式之后,我正在寻找其他有用的东西。
我正在寻找清理旧 HTML 表(使用 PHP)的最佳方法,以便它们是正确的 HTML5 表 - 这主要是剥离不允许的属性的问题。除此之外,我还想去除这些表格的内联样式。如果能一口气完成就太好了。
我一直在研究正则表达式,但是在阅读了不建议执行正则表达式之后,我正在寻找其他有用的东西。
一个关于如何使用 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>';