商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) HG 機動戦士ガンダム 閃光のハサウェイ グスタフ・カール00型 1/144スケール プラスチック製 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
ホットウィール(Hot Wheels) カーカルチャー スリル クライマーズ 三菱 ランサー エボリューション VI 乗り物おもちゃ ミニカー 3歳から レッド JKF19
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
剣と魔法と学園モノ。2 ザ・コンプリートガイド
商品ページ
Amazon
収益広告(手動登録)
サクラ度:○(問題なし)
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) 30MS 30 MINUTES SISTERS 水転写式デカール 汎用③ ノンスケール
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
D.C.Ⅱ.S.S.~ダ・カーポⅡセカンドシーズン~(TV番組)
商品ページ
Amazon
非収益広告(手動登録)
サクラ度:○(問題なし)
記事の概要
htmlタグ混在のテキストをhtmlタグとプレーンテキストで分けるJavaScriptコード
作成日:2025-06-20
最終更新日:2025-06-20
記事の文字数:2162
本記事のトピック
  • 概要
  • JavaScriptコード
htmlタグ混在のテキストをhtmlタグとプレーンテキストで分けるJavaScriptコード
概要

「よくある質問は<a href="/">こ<span>ち</span>ら</a>です」 というようなhtmlタグ混在のテキストを、htmlタグとプレーンテキストごとに分けるJavaScriptコードです。

「よくある質問は<a href="/">こ<span>ち</span>ら</a>です」 であれば、以下のような出力になります。

const htmlText = よくある質問は<a href="/">こ<span>ち</span>ら</a>です; const separatedHtmlText = separateHtmlText(htmlText); console.log(separatedHtmlText); //[ // { // "htmlText": "よくある質問は", // "type": "text", // "tag": null // }, { // "htmlText": "<a href=\"/\">", // "type": "tagOpen", // "tag": "a" // }, { // "htmlText": "こ", // "type": "text", // "tag": null // }, { // "htmlText": "<span>", // "type": "tagOpen", // "tag": "span" // }, { // "htmlText": "ち", // "type": "text", // "tag": null // }, { // "htmlText": "</span>", // "type": "tagClose", // "tag": "span" // }, { // "htmlText": "ら", // "type": "text", // "tag": null // }, { // "htmlText": "</a>", // "type": "tagClose", // "tag": "a" // }, { // "htmlText": "です", // "type": "text", // "tag": null // } //]
JavaScriptコード

実際のJavaScriptコードは以下です。

function separateHtmlText(htmlText){ const htmlTextElm = new DOMParser().parseFromString(htmlText, 'text/html').body; const results = separateNode(htmlTextElm); return(results); } function separateNode(nodes){ const results = []; for (const child of nodes.childNodes) { if (child.nodeType === Node.TEXT_NODE) { // プレーンテキスト results.push(createSeparateObj(child.textContent, 'text')); } else if (child.nodeType === Node.ELEMENT_NODE) { // タグ開始 const tagName = child.tagName.toLowerCase(); const tagAttrs = [...child.attributes].map(attr => `${attr.name}="${attr.value}"`).join(' '); const tagOpen = `<${tagName}${tagAttrs ? ' ' + tagAttrs : ''}>`; const tagClose = ``; results.push(createSeparateObj(tagOpen, 'tagOpen', tagName)); const r = separateNode(child); results.push(...r); results.push(createSeparateObj(tagClose, 'tagClose', tagName)); } } return results; function createSeparateObj(htmlText, type, tag = null){ const result = { text: htmlText, type: type, tag: tag, }; return result; } }

上にも書いてありますが、基本的な使い方は以下です。

const htmlText = よくある質問は<a href="/">こ<span>ち</span>ら</a>です; const separatedHtmlText = separateHtmlText(htmlText);

文字列ではなく、html要素自体を渡したい場合は以下で動くはずです。

const targetElm = document.getElementById('targetElmId') const separatedHtmlText = separateNode(targetElm);
コメントログ
※コメントは最新50件が表示されます
コメント投稿




画面下部の「コンタクト」からも連絡可能です。
管理人ツイート
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) HG マクロスF VF-25G メサイアバルキリー(ミハエル・ブラン機) 1/100スケール 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) 30MF クラスアップアーマー(鉄禍ノ僧兵) ノンスケール 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) 30MF クラスアップアーマー(鉄禍ノ将軍) ノンスケール 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) 30MM DAEMON X MACHINA TS オプションパーツセット WEAPON SET 01 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)
管理人作品宣伝
VRoidテクスチャミキサー
Webサイト / 最終更新:2025-05-23
【一部機能返礼特典】本ツールはVRoidテクスチャを作成するためのもので、複数の画像を…【一部機能返礼特典】本ツールはVRoidテクスチャを作成するためのもので、複数の画像をレイヤーを重ねて合成できます。 とは言っても細かい設定は現状できないため、用途としては以下です。 ・VRoidStudioのテクスチャの色を変えたり、飾りを付けたり、キャラクターをTシャツの胸のあたりに載せるとか ・シンプルな衣装(下着や靴下など)に模様や飾りを付ける ・衣装の色や大まかなデザインを検討したいとき 「レイヤーの移動・リサイズ」や「カラーコードの自由追加」は正式版でのみ利用可能です。

HPで閲覧する(デモ版)HPで閲覧する(正式版)利用素材等の詳細情報返礼特典
ジグソーパズル風パズルゲーム
Webサイト / 最終更新:2025-01-23
ジグソーパズル風パズルゲームです。自分で画像を設定してパズルにできます。…ジグソーパズル風パズルゲームです。自分で画像を設定してパズルにできます。

HPで閲覧する利用素材等の詳細情報
作品一覧はこちら
関連ページ
本サイトのタグ一覧
NovelAIR18VRoidWebサイト作成Webツールととモノ。るろうに剣心アークナイツアークナイツ-ステージ攻略日記アズールレーンアズールレーン-日記ウマ娘ギャラリーゲームデビラビローグネットスラング系プログラミングホラーポケットタウン怪談気ままな日記逆転裁判情報技術情報技術-WebAPI知的財産権統合戦略白夜極光本サイトについて魔王スライム様がんばる!漫画
人気記事
ととモノ。3:各学科の強みを一覧化
最終更新日:2025-10-12
スコア:1647.0486 pt
このページのポイントどの学科が良いかすぐに分かる各学科のどのような点が良いか分かる各役割で欲しいスキ…
記事を閲覧する
ポケットタウン_パズル一覧
最終更新日:2025-05-02
スコア:831.7440 pt
グレーのピースの数 (Number of gray pieces):検索グレーピースの数を入力して、…
記事を閲覧する
メイド・オブ・ザ・デッド-攻略お助け情報
最終更新日:2024-05-01
スコア:669.4939 pt
ネタバレ注意! 本ページは『メイド・オブ・ザ・デッド』の情報を記録しているものです。 攻略の参考に…
記事を閲覧する
TRICK-本物っぽい霊能力者
最終更新日:2025-02-06
スコア:669.2810 pt
概要 TRICKは基本的にインチキ霊能力者のインチキを暴いていく話ですが、中にはトリックでは説明が…
記事を閲覧する
剣と魔法と学園モノ。2G - パーティ編成確認ツール
最終更新日:2024-05-09
スコア:362.7009 pt
ツール概要 ととモノ。2Gのパーティ編成を考える際に使うツールです。 あくまでストーリークリアまで…
記事を閲覧する
ヒカルの碁で、なぜ佐為は消えたのか
最終更新日:2025-04-21
スコア:338.1512 pt
概要 ヒカルの碁で佐為が消えた理由について、「ヒカルの才能を目覚めさせるという役割を終えたから」と…
記事を閲覧する
剣と魔法と学園モノ。3 前作からの変更点
最終更新日:2025-10-12
スコア:329.8226 pt
概要 もうそろそろ「ととモノ。3」のリマスターが出るので、自分自身のための振り返りと言う意味も込め…
記事を閲覧する
剣と魔法と学園モノ。3 - パーティ編成確認ツール
最終更新日:2025-09-23
スコア:293.8834 pt
ツール概要 ととモノ。3のパーティ編成を考える際に使うツールです。 攻略本や攻略wikiを参考にし…
記事を閲覧する
最新記事
鉄鍋のジャン:ジャンのいいところを知ってほしい
最終更新日:2026-02-14
ネタバレ注意※本記事にはネタバレが含まれます。このページのポイントジャンは本当にクズなのかジャンのい…
記事を閲覧する
るろうに剣心-各キャラの持つ正義
最終更新日:2026-01-12
このページのポイントこんな人向けるろ剣を読んだことないけど知ってる人軽く読んだことがある人伝えたいこ…
記事を閲覧する
逆転裁判1:真犯人まとめと悪質度
最終更新日:2025-12-15
概要 逆転裁判1(蘇る込み)に出てくる犯人たちを、やったことや動機なんかを整理して「悪質度」を点数…
記事を閲覧する
OpenAI API:Webサーチモードで参考にしてほしいURLを送っても無視されることがある問題について
最終更新日:2025-12-07
このページのポイントWebサーチでも、まずは「プロンプトだけ」を読んで「解釈」される「前提として見て…
記事を閲覧する
商品サンプル画像
BANDAI SPIRITS(バンダイ スピリッツ) 30MM xEXM-000 ゼノヴァルト 1/144スケール 色分け済みプラモデル
商品ページ
Amazon
収益広告(自動登録)
サクラ度:△(要確認)