質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

1315閲覧

phpのDOMでhtmlタグの置き換え

helloman

総合スコア39

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/08/29 10:46

編集2018/08/30 00:54

phpでDOM操作に挑戦中です。

$dom = new DOMDocument(); $dom->loadHTML($content); $divs = $dom->getElementsByTagName('div'); foreach ($divs as $div): if ($div->hasAttribute('class') && preg_match('/target-class/i', $div->getAttribute('class'))) { ---- } endforeach; $dom->saveHTML();

$contentは

<div class="target-class">hogehoge</div> <div class="no">hogehoge</div> <div class="target-class">hogehoge</div> <div class="target-class">hogehoge</div> <div class="no">hogehoge</div> <div class="target-class">hogehoge</div> <div class="no">hogehoge</div> <div class="no">hogehoge</div> <div class="target-class">hogehoge</div> ```です。 $contentの内容を ```ここに言語を入力 <p class="target-class"><span class="target-class-inner">hogehoge</span></p> <div class="no">hogehoge</div> <p class="target-class"><span class="target-class-inner">hogehoge</span></p> <div class="target-class">hogehoge</div> <div class="no">hogehoge</div> <p class="target-class"><span class="target-class-inner">hogehoge</span></p> <div class="no">hogehoge</div> <div class="no">hogehoge</div> <p class="target-class"><span class="target-class-inner">hogehoge</span></p> ```みたいな形にするにはどうしたらいいでしょうか? 単純にdivタグを別のタグ名にしたいのです。 ### 現在実行している方法 ```ここに言語を入力 $dom = new DOMDocument(); $dom->loadHTML($content); $divs = $dom->getElementsByTagName('div'); foreach ($divs as $div): if ($div->hasAttribute('class') && preg_match('/target-class/i', $div->getAttribute('class'))) { $new_p = $dom->createElement('p'); // 属性を全部コピー foreach ($div->attributes as $attr) { $new_p->setAttribute($attr->nodeName, $attr->nodeValue); } $new_p_content = $div->nodeValue; $new_p->nodeValue = "<span class=\"target-class-inner\">{$new_p_content}</span>"; $div->parentNode->replaceChild($new_p, $div); } endforeach; return mb_convert_encoding($dom->saveHTML(), 'UTF-8', 'HTML-ENTITIES');

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

別途で<p>タグをcreateElementして中身を移す、しかありません。

単純にdivタグを別のタグ名にしたいのです。

DOMの世界では、タグの種類ごとに別のクラスなので、「タグを変更する」ような方法はありません。

投稿2018/08/29 10:54

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

helloman

2018/08/30 00:44

回答ありがとうございます。createElementを利用した方法を追記しました。 もしよかったら確認していただけると嬉しいです。$new_p->nodeValueの部分が微妙かなと思っています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問