使用Symfony DomCrawler获取元素的原始HTML代码


Get raw HTML code of element with Symfony DomCrawler

Html结构:

   <div id="product">
     <p>some text</p>
     <p>some text2</p>
   </div>    
我的PHP代码:
$client = new Client();
$crawler = $client->request('GET', $url);
echo $crawler->filter('#product')->text();

的回报:

some text some text2

但是我需要:

<p>some text</p>
<p>some text2</p>

嗯,有一种难看的方法——通过遍历它的节点:

$html = '';
foreach ($crawler as $domElement) {
    $html.= $domElement->ownerDocument->saveHTML();
}

或者,在您的情况下,您应该遍历过滤元素:

$html = '';     
$product = $crawler->filter('#produkt');
 
foreach ($product as $domElement) {
    foreach($domElement->childNodes as $node) {
        $html .= $domElement->ownerDocument->saveHTML($node);
    }
}
从文档