source

내부로 들어가는 방법DOMNode의 HTML?

goodcode 2022. 10. 26. 21:48
반응형

내부로 들어가는 방법DOMNode의 HTML?

어떤 기능을 사용하여 내부 정보를 얻습니까?PHP DOM 구현에서 주어진 DOMNode의 HTML?누군가 신뢰할 수 있는 해결책을 줄 수 있나요?

물론 외부입니다.HTML도 괜찮아요.

업데이트된 버전을 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); 
} 
?> 

기능적 프로그래밍 스타일의 버전은 다음과 같습니다.

function innerHTML($node) {
    return implode(array_map([$node->ownerDocument,"saveHTML"], 
                             iterator_to_array($node->childNodes)));
}

「 」를 htmlC14N()을 사용할 수 있습니다.

$dom = new DOMDocument();
$dom->loadHtml($html);
$x = new DOMXpath($dom);
foreach($x->query('//table') as $table){
    echo $table->C14N();
}

Haim 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.

트린콧의 멋진 버전에다가array_map ★★★★★★★★★★★★★★★★★」implode 에는 ★★★★★★★★★★★★★★★★★★★★★★★.array_reduce:

return array_reduce(
   iterator_to_array($node->childNodes),
   function ($carry, \DOMNode $child) {
        return $carry.$child->ownerDocument->saveHTML($child);
   }
);

안가네, 돼?reduce()어레이와 반복기를 모두 수용하는 방식입니다.

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);
  }
}

다음은 Drupella가 php.net에 올린 코멘트를 바탕으로 한 또 다른 접근법으로 제 프로젝트에 도움이 되었습니다.이 명령어는innerHTML() ""를 DOMDocument(자노드 상에서 명시적으로 반복하지 않고 타깃노드를 Import하여 추가합니다).

이너HTML

다음 도우미 기능을 정의합니다.

function innerHTML( \DOMNode $n, $include_target_tag = true ) {
  $doc = new \DOMDocument();
  $doc->appendChild( $doc->importNode( $n, true ) );
  $html = trim( $doc->saveHTML() );
  if ( $include_target_tag ) {
      return $html;
  }
  return preg_replace( '@^<' . $n->nodeName .'[^>]*>|</'. $n->nodeName .'>$@', '', $html );
}

두 번째 입력 인수를 통해 외부 대상 태그를 포함/지정할 수 있습니다.

사용 예

여기서는 "first" id 속성에 의해 지정된 타겟태그의 내부 HTML을 추출합니다.

$html = '<div id="first"><h1>Hello</h1></div><div id="second"><p>World!</p></div>';
$doc  = new \DOMDocument();
$doc->loadHTML( $html );
$node = $doc->getElementById( 'first' );

if ( $node instanceof \DOMNode ) {

    echo innerHTML( $node, true );
    // Output: <div id="first"><h1>Hello</h1></div>    

    echo innerHTML( $node, false );
    // Output: <h1>Hello</h1>
}

라이브 예:

http://sandbox.onlinephpfunctions.com/code/2714ea116aad9957c3c437d46134a1688e9133b8

오래된 쿼리이지만 이를 위한 기본 제공 방법이 있습니다. 됩니다.DomDocument->saveHtml().

완전한 예:

$html = '<div><p>ciao questa è una <b>prova</b>.</p></div>';
$dom = new DomDocument($html);
@$dom->loadHTML($html);
$xpath = new DOMXPath($dom);
$node = $xpath->query('.//div/*'); // with * you get inner html without surrounding div tag; without * you get inner html with surrounding div tag
$innerHtml = $dom->saveHtml($node);
var_dump($innerHtml);

★★★★★<p>ciao questa è una <b>prova</b>.</p>

XPath 쿼리에서 HTML을 가져오고 싶은 사용자를 위해 내 버전은 다음과 같습니다.

$xpath = new DOMXpath( $my_dom_object );

$DOMNodeList = $xpath->query('//div[contains(@class, "some_custom_class_in_html")]');

if( $DOMNodeList->count() > 0 ) {
    $page_html = $my_dom_object->saveHTML( $DOMNodeList->item(0) );
}

언급URL : https://stackoverflow.com/questions/2087103/how-to-get-innerhtml-of-domnode

반응형