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

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

ただいまの
回答率

90.52%

  • HTML

    8970questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • HTML5

    4015questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • SVG

    100questions

    SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

SVG内のcontenteditableが効かない

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 140

tarotarosu

score 102

 前提・実現したいこと

厳密にはcontenteditableが効かないわけではなく、「フォーカスが合わない」という問題が発生しています。

今、下記のようなSVGを描画させるhtmlファイルがあります。

 normal.html

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
    <div>
      <svg style="border: 1px solid rgba(0, 0, 0, 0.4);" class="injected-svg" xml:space="preserve" enable-background="new 0 0 533 1071.6" viewBox="0 0 533 1071.6" y="0px" x="0px" id="Top" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg">
          <g xmlns="http://www.w3.org/2000/svg" id="Background">
              <rect fill="#FFFFFF" width="533" height="1071.6"></rect>
          </g>
        <g xmlns="http://www.w3.org/2000/svg" id="Name">
          <foreignObject xmlns="" x="0" y="897.6101000000001" width="533" height="100" font-size="48" font-family="NotoSansCJKjp-Regular">
            <div xmlns="http://www.w3.org/1999/xhtml" style="text-align: center;">
              <span xmlns="http://www.w3.org/1999/xhtml" contenteditable="true">Name</span>
            </div>
          </foreignObject>
        </g>
          <g xmlns="http://www.w3.org/2000/svg" id="Message">
          <foreignObject xmlns="" x="0" y="0" width="533" height="336.7" font-size="64" font-family="NotoSansCJKjp-Regular">
            <div xmlns="http://www.w3.org/1999/xhtml" style="width: 533px; height: 336.7px; display: flex; flex-direction: column; justify-content: center; text-align: center; line-height: 1.1;">
              <span xmlns="http://www.w3.org/1999/xhtml" contenteditable="true">Message</span>
            </div>
          </foreignObject>
        </g>
      </svg>
    </div>
  </body>
</html>

<span>contenteditable属性を持たせ、テキスト編集できるようにしました。

<span xmlns="http://www.w3.org/1999/xhtml" contenteditable="true">Message</span>

normal.htmlの方は何も問題なく<span>で囲まれたテキストをクリックし、フォーカスを当て、テキストを編集することができます。

しかし、下記(big.html)のようにサイズをものすごく大きくしたSVGを表示した場合、<span>で囲まれたテキストをクリックしてもフォーカスが合いません(テキスト部分をクリックしてもキャレットが表示されません)。
id=Name内の<span>の場合、「N」の横周辺をクリックするとなんとかフォーカスがあってくれることがあります。

 big.html

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
    <div>
      <svg style="border: 1px solid rgba(0, 0, 0, 0.4);" class="injected-svg" xml:space="preserve" enable-background="new 0 0 4989 10431.5" viewBox="0 0 4989 10431.5" y="0px" x="0px" id="Top" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg">
        <g xmlns="http://www.w3.org/2000/svg" id="Background">
            <rect x="56.7" y="141.7" fill="#FFFFFF" width="4875.6" height="10148"></rect>
        </g>
        <g xmlns="http://www.w3.org/2000/svg" id="Name">
          <foreignObject xmlns="" x="0" y="7849" width="4989" height="100" font-size="500" font-family="NotoSansCJKjp-Regular">
            <div xmlns="http://www.w3.org/1999/xhtml" style="text-align: center;">
              <span xmlns="http://www.w3.org/1999/xhtml" contenteditable="true">Name</span>
            </div>
          </foreignObject>
        </g>
        <g xmlns="http://www.w3.org/2000/svg" id="Message">
          <foreignObject xmlns="" x="0" y="141.7" width="4989" height="2915.3" font-size="700" font-family="NotoSansCJKjp-Regular">
            <div xmlns="http://www.w3.org/1999/xhtml" style="width: 4989px; height: 2915.3px; display: flex; flex-direction: column; justify-content: center; text-align: center; line-height: 1.1;">
              <span xmlns="http://www.w3.org/1999/xhtml" contenteditable="true">Message</span>
            </div>
          </foreignObject>
        </g>
      </svg>
    </div>
  </body>
</html>

normal.htmlのようにテキストのどこをクリックしてもフォーカスが合い、テキストを編集できるようにしたいのですが、
原因は何なのでしょうか?
また、どうすれば解決できるのでしょうか?
何かご回答を頂けると助かります<(_ _)>

 追記

Firefoxでbig.htmlを表示して試してみたところ、<span>内のテキストをクリックしたところ、テキスト編集がてきました。しかし、id=Nameの部分はなぜかテキストの表示すらされませんでした。
ホントに原因がわからない...

 追記2

下図の青く囲んだ部分あたりをクリックするとテキストにフォーカスが当たり、テキストを編集できます。
イメージ説明

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

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

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • HTML

    8970questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • HTML5

    4015questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • SVG

    100questions

    SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。