72
A
回答
118
Compare該更新的變種與PHP Manual User Note #89718:
<?php
function DOMinnerHTML(DOMNode $element)
{
$innerHTML = "";
$children = $element->childNodes;
foreach ($children as $child)
{
$innerHTML .= $element->ownerDocument->saveHTML($child);
}
return $innerHTML;
}
?>
例子:
<?php
$dom= new DOMDocument();
$dom->preserveWhiteSpace = false;
$dom->formatOutput = true;
$dom->load($html_string);
$domTables = $dom->getElementsByTagName("table");
// Iterate over DOMNodeList (Implements Traversable)
foreach ($domTables as $table)
{
echo DOMinnerHTML($table);
}
?>
3
function setnodevalue($doc, $node, $newvalue){
while($node->childNodes->length> 0){
$node->removeChild($node->firstChild);
}
$fragment= $doc->createDocumentFragment();
$fragment->preserveWhiteSpace= false;
if(!empty($newvalue)){
$fragment->appendXML(trim($newvalue));
$nod= $doc->importNode($fragment, true);
$node->appendChild($nod);
}
}
6
3
簡化哈伊姆Evgi的回答版本:
<?php
function innerHTML(\DOMElement $element)
{
$doc = $element->ownerDocument;
$html = '';
foreach ($element->childNodes as $node) {
$html .= $doc->saveHTML($node);
}
return $html;
}
用法示例:
<?php
$doc = new \DOMDocument();
$doc->loadHTML("<body><div id='foo'><p>This is <b>an <i>example</i></b> paragraph<br>\n\ncontaining newlines.</p><p>This is another paragraph.</p></div></body>");
print innerHTML($doc->getElementById('foo'));
/*
<p>This is <b>an <i>example</i></b> paragraph<br>
containing newlines.</p>
<p>This is another paragraph.</p>
*/
有沒有必要設置preserveWhiteSpace
或formatOutput
。
14
這裏是一個函數式編程風格版本:
function innerHTML($node) {
return implode(array_map([$node->ownerDocument,"saveHTML"],
iterator_to_array($node->childNodes)));
}
4
除了trincot的漂亮版本array_map
和implode
但這次array_reduce
:
return array_reduce(
iterator_to_array($node->childNodes),
function ($carry, \DOMNode $child) {
return $carry.$child->ownerDocument->saveHTML($child);
}
);
仍然不理解,爲什麼沒有reduce()
方法接受數組和迭代器。
相關問題
- 1. 獲取插入DOMNode
- 2. PHP獲取DOMNode的XPath
- 3. 如何從的DOMNode
- 4. 如何從javascript中的innerHTML獲取id?
- 5. 在php中獲取'DomNode'類型對象
- 6. jquery獲取UL innerhtml
- 7. 從XMLHttpResponse獲取innerHTML
- 8. 從DOMNode獲取文本後如何修剪
- 9. 獲取的innerHTML從選擇
- 10. 獲取的innerHTML通過Jsoup
- 11. jQuery:獲取內容/ innerhtml onclick
- 12. BeautifulSoup獲取innerhtml數據
- 13. 從Frameset中獲取InnerHTML
- 14. python webdriver:從innerHTML獲取XPATH
- 15. 如何獲取包含值的輸入控件的innerHTML?
- 16. dijit.WidgetSet domNode
- 17. DomNode htmlunit
- 18. SVG上的JS - 獲取元素的innerHTML
- 19. DomNode獲得項目的價值
- 20. 如何獲得React組件的innerHTML
- 21. 如何獲得嵌套節點的innerHTML
- 22. 如何在javascript中獲取此元素的innerHTML?
- 23. 如何在ASP.net後面的代碼中獲取Textarea InnerHTML
- 24. 如何從單擊元素的相關節點獲取innerHTML/innerText?
- 25. 如何從插入到innerHtml中的單選按鈕獲取值
- 26. 如何通過搜索innerHTML的內容來獲取HTML元素?
- 27. 如何獲取innerHTML中的原始html字符串?
- 28. MVC3如何從@Html.ValidationMessageFor <>方法的返回sth獲取innerHtml?
- 29. 如何從Javascript中的innerhtml獲取特定值?
- 30. 如何在selenium驅動中獲取整個頁面的innerHTML?
謝謝。它工作正常。不應該$ dom-> preserveWhiteSpace = false;在文件加載之前? – JohnM2 2010-01-18 18:59:23
@ JohnM2:[是的,應該](http://stackoverflow.com/questions/798967/php-simplexml-how-to-save-the-file-in-a-formatted-way)。 – hakre 2013-06-23 18:35:31
附加說明:自PHP 5.3.6開始,您可以省去臨時的'DOMDocument'。還有人可能想用'ltrim'替換'trim'(甚至完全刪除它)以保留一些空白,如分行符。 – hakre 2013-06-23 22:01:54