PHP Dom删除元素留下内容

Jac*_*ack 7 html php xpath dom

我试图删除某些链接取决于他们的ID标记,但保留链接的内容.例如,我想转

Some text goes <a href="http://www.domain.tdl/" id="remove">here</a>
Run Code Online (Sandbox Code Playgroud)

Some text goes here
Run Code Online (Sandbox Code Playgroud)

我尝试过使用以下内容.

$dom = new DOMDocument;
$dom->loadHtml(mb_convert_encoding($html, 'HTML-ENTITIES', "UTF-8"));
$xp = new DOMXPath($dom);

foreach($xp->query('//a[contains(@id="remove")]') as $oldNode) {
$revised = strip_tags($oldNode);
}

$revised = mb_substr($dom->saveXML($xp->query('//body')->item(0)), 6, -7, "UTF-8");
echo $revised;
Run Code Online (Sandbox Code Playgroud)

大致从这里开始,但它只是吐出相同的内容$html.

有什么想法我会如何实现这一目标?

net*_*der 14

这是我的功能:

function DOMRemove(DOMNode $from) {
    $sibling = $from->firstChild;
    do {
        $next = $sibling->nextSibling;
        $from->parentNode->insertBefore($sibling, $from);
    } while ($sibling = $next);
    $from->parentNode->removeChild($from);    
}
Run Code Online (Sandbox Code Playgroud)

所以这:

$dom->loadHTML('Hello <a href="foo"><span>World</span></a>');
$a = $dom->getElementsByTagName('a')->item(0); // get first
DOMRemove($a);
Run Code Online (Sandbox Code Playgroud)

应该给你:

Hello <span>World</span>
Run Code Online (Sandbox Code Playgroud)

要获取具有特定ID的节点,请使用XPath:

$xpath = new DOMXpath($dom);
$node = $xpath->query('//a[@id="something"]')->item(0); // get first
DOMRemove($node);
Run Code Online (Sandbox Code Playgroud)