请考虑以下PHP代码
<?php
$html_data =
'<html><body>
<ol>
<li><strong>Question 1</strong> Answer1</li>
<li><strong>Question 2</strong> Answer2</li>
</ol></body></html>';
$doc = new DOMDocument();
$doc->loadHTML($html_data);
$xpath = new DOMXPath($doc);
$ols = $xpath->query('//ol');
$ol = $ols->item(0);
$lis = $ol->childNodes;
foreach ($lis as $li) {
echo $li->firstChild->nodeValue."<br />";
echo $li->lastChild->nodeValue."<br />";
//echo $li->childNodes->item(0)->nodeValue."<br />";
}
?>
Run Code Online (Sandbox Code Playgroud)
如果我删除此代码最后一行的注释并访问childNodes DOM Object Array,我的foreach循环只执行一次.但是,如果我使用firstChild和lastChild访问相同的元素,如上所示,我可以成功迭代所有存在的'li'标签.
我根本无法理解这一点.这是PHP中的错误吗?
如果您不抑制错误报告,您就会发现一个致命错误会破坏您的脚本。
为了使用item方法:
foreach ($lis as $li) {
if (method_exists($li->childNodes, 'item')) {
echo $li->childNodes->item(0)->nodeValue."<br />";
// To reproduce the exact output you need this line also.
// You need to display the second child (Answer)
echo $li->childNodes->item(1)->nodeValue."<br />";
}
}
Run Code Online (Sandbox Code Playgroud)
唯一的区别是第一个脚本
foreach ($lis as $li) {
echo $li->firstChild->nodeValue."<br />";
echo $li->lastChild->nodeValue."<br />";
//echo $li->childNodes->item(0)->nodeValue."<br />";
}
Run Code Online (Sandbox Code Playgroud)
仅抛出注意:尝试获取非对象的属性,但脚本继续。
与方法 item() 一样,它会抛出致命错误。(致命错误:调用非对象上的成员函数 item())。这会杀死你的脚本。
有关如何迭代这些节点列表(foreach 与 for)的更多详细信息,请阅读这些页面中的注释
由于<li>标签后面有尾随空格,您尤其会遇到这个问题。
它像这样循环:第一个<li>标签,然后是空格' ' DOMText元素,然后是第二个<li>标签,然后是第二个' ' DOMText元素。
在 DOMText 元素上它崩溃了。你可以清理空间并且它会起作用。
$html_data = '<html><body><ol><li><strong>Question 1</strong> Answer1</li><li><strong>Question 2</strong> Answer2</li></ol></body></html>';
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3235 次 |
| 最近记录: |