加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 使用HTML DOM替换第一个标记

发布时间:2020-12-13 22:28:04 所属栏目:PHP教程 来源:网络整理
导读:问:根据任务,我需要替换 p仅使用 HTML DOM标记第一次出现的h4. 我尝试使用this question,但无法成功 我的代码, HTML div class="productabcont" div class="protabtop" div class="protabtopright" pCombed compact yarn/p !-- This i want to replace with
问:根据任务,我需要替换< p>仅使用 HTML DOM标记第一次出现的h4.

我尝试使用this question,但无法成功

我的代码,

HTML

<div class="productabcont">
    <div class="protabtop">
        <div class="protabtopright">
            <p>Combed compact yarn</p> <!-- This i want to replace with <h4> tag. -->
            <p>Description line 1</p>
            <p>Description line 2</p>
        </div>
    </div>          
</div>

PHP

<?php    
    $dom = new DOMDocument();
    $dom->loadHTML($myHTML);
    $dom->getElementsByTagName('p')[0]->outertext = '<h4>'.$value.'</h4>';
    $dom->saveHTML();
?>

要求的输出

<div class="productabcont">
    <div class="protabtop">
        <div class="protabtopright">
            <h4>Combed compact yarn</h4> <!-- This is replaced with <p> tag. -->
            <p>Description line 1</p>
            <p>Description line 2</p>
        </div>
    </div>          
</div>

提前致谢.

解决方法

使用DOM *对象时没有outerHTML.但您可以使用所有其他可用工具.

例如:

<?php

$html = <<<HTML
<div class="productabcont">
    <div class="protabtop">
        <div class="protabtopright">
            <p>Combed compact yarn</p> <!-- This i want to replace with <h4> tag. -->
            <p>Description line 1</p>
            <p>Description line 2</p>
        </div>
    </div>          
</div>
HTML;

$value = 'some headline';

$dom = new DOMDocument();
$dom->loadHTML($html);

$q = new DOMXPath($dom);

// find first p tag
foreach ($q->query('//p[1]') as $p) {
    // replace it with newly created element
    $p->parentNode->replaceChild($dom->createElement('h4',$value),$p);
}

echo $dom->saveHTML();

当然,您不需要将xpath用于这样一个简单的示例,但如果您稍后需要更明确地说明需要替换哪个节点,则可以轻松扩展.

演示:https://3v4l.org/4Hj1e

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读