diff options
Diffstat (limited to 'files/ja/web/api/text')
-rw-r--r-- | files/ja/web/api/text/index.html | 106 | ||||
-rw-r--r-- | files/ja/web/api/text/splittext/index.html | 118 |
2 files changed, 224 insertions, 0 deletions
diff --git a/files/ja/web/api/text/index.html b/files/ja/web/api/text/index.html new file mode 100644 index 0000000000..691cc5581d --- /dev/null +++ b/files/ja/web/api/text/index.html @@ -0,0 +1,106 @@ +--- +title: Text +slug: Web/API/Text +tags: + - API + - DOM +translation_of: Web/API/Text +--- +<p>{{ApiRef("DOM")}}</p> + +<p><strong><code>Text</code></strong> インターフェイスは、{{domxref("Element")}} または {{domxref("Attr")}} のテキストコンテンツを表します。要素の内部にマークアップが含まれていない場合、その要素は要素内のテキストを包含する <code>Text</code> を実装する子を 1 つ持ちます。一方要素がマークアップを含む場合は情報アイテムと、要素の子を構成する <code>Text</code> ノードに解析されます。</p> + +<p>新しいドキュメントは、テキストのブロックごとに 1 つの <code>Text</code> ノードを持ちます。ドキュメントの内容の変化に応じて、さらに多くの <code>Text</code> ノードが生成されます。{{domxref("Node.normalize()")}} メソッドは、テキストのブロックごとに 1 つのノードに戻るよう、隣接する <code>Text</code> オブジェクトを結合します。</p> + +<p>{{InheritanceDiagram}}</p> + +<h2 id="Methods" name="Methods">コンストラクター</h2> + +<dl> + <dt>{{domxref("Text.Text", "Text()")}} {{experimental_inline}}</dt> + <dd>引数をテキストコンテンツとして持つ、<code>Text</code> ノードを返します。</dd> +</dl> + +<h2 id="Properties" name="Properties">プロパティ</h2> + +<p><em>親である {{domxref("CharacterData")}} からプロパティを継承します。</em></p> + +<dl> + <dt>{{domxref("Text.isElementContentWhitespace")}} {{readonlyInline}} {{obsolete_inline}}</dt> + <dd>text ノードがホワイトスペースしか包含していないかを示す、{{domxref("Boolean")}} フラグを返します。</dd> + <dt>{{domxref("Text.wholeText")}} {{readonlyInline}}</dt> + <dd>当該 {{domxref("Node")}} に論理的に隣接しているすべての <code>Text</code> ノードのテキストを、ドキュメント内で現れる順に結合した {{domxref("DOMString")}} を返します。</dd> + <dt>{{domxref("Text.assignedSlot")}} {{readonlyinline}}</dt> + <dd>要素に関連付けられた {{domxref("HTMLSlotElement")}} オブジェクトを返します。</dd> +</dl> + +<h3 id="Properties_included_from_Slotable" name="Properties_included_from_Slotable">Slotable に含まれるプロパティ</h3> + +<p><em><code>Text</code> インターフェイスは、{{domxref("Slotable")}} ミックスインで定義された以下のプロパティを含んでいます。</em></p> + +<dl> + <dt>{{domxref("Slotable.assignedSlot")}} {{readonlyInline}}</dt> + <dd>ノードが挿入されている {{htmlelement("slot")}} を表す {{domxref("HTMLSlotElement")}} を返します。</dd> +</dl> + +<h2 id="Methods" name="Methods">メソッド</h2> + +<p><em>親である {{domxref("CharacterData")}} からメソッドを継承します。</em></p> + +<dl> + <dt>{{domxref("Text.replaceWholeText")}} {{obsolete_inline}}</dt> + <dd>カレントノードおよび論理的に隣接するノードのテキストを、指定したテキストに置き換えます。</dd> +</dl> + +<dl> + <dt><span>{{domxref("Text.splitText")}}</span></dt> + <dd>指定したオフセット位置で、ノードを 2 つに分割します。</dd> +</dl> + +<h2 id="Specifications" name="Specifications">仕様</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">仕様書</th> + <th scope="col">策定状況</th> + <th scope="col">コメント</th> + </tr> + <tr> + <td>{{SpecName('DOM WHATWG', '#text', 'Text')}}</td> + <td>{{Spec2('DOM WHATWG')}}</td> + <td><code>isElementContentWhitespace</code> プロパティを削除。<br> + <code>replaceWholeText()</code> メソッドを削除。<br> + <code>Text()</code> コンストラクターを追加。<br> + <code>assignedSlot</code> プロパティを追加。</td> + </tr> + <tr> + <td>{{SpecName('DOM3 Core', 'core.html#ID-1312295772', 'Text')}}</td> + <td>{{Spec2('DOM3 Core')}}</td> + <td><code>isElementContentWhitespace</code> および <code>wholeText</code> プロパティを追加。<br> + <code>replaceWholeText()</code> メソッドを追加。</td> + </tr> + <tr> + <td>{{SpecName('DOM2 Core', 'core.html#ID-1312295772', 'Text')}}</td> + <td>{{Spec2('DOM2 Core')}}</td> + <td>{{SpecName('DOM1')}} から変更なし。</td> + </tr> + <tr> + <td>{{SpecName('DOM1', 'level-one-core.html#ID-1312295772', 'Text')}}</td> + <td>{{Spec2('DOM1')}}</td> + <td>最初期の定義</td> + </tr> + </tbody> +</table> + +<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザー実装状況</h2> + + + +<p>{{Compat("api.Text")}}</p> + +<h2 id="See_also" name="See_also">関連情報</h2> + +<ul> + <li><a href="/ja/docs/DOM/DOM_Reference" title="DOM/DOM_Reference">DOM インターフェイスの索引</a></li> +</ul> diff --git a/files/ja/web/api/text/splittext/index.html b/files/ja/web/api/text/splittext/index.html new file mode 100644 index 0000000000..a5895401d9 --- /dev/null +++ b/files/ja/web/api/text/splittext/index.html @@ -0,0 +1,118 @@ +--- +title: Text.splitText() +slug: Web/API/Text/splitText +tags: + - API + - DOM + - Method + - Text + - splitText + - メソッド +translation_of: Web/API/Text/splitText +--- +<p>{{APIRef("DOM")}}</p> + +<p><strong><code>Text.splitText()</code></strong> メソッドは、 {{domxref("Text")}} ノードを指定したオフセットで二つに分割し、両方のノードを兄弟としてツリーの中に保持します。</p> + +<p>分割後、現在のノードには指定したオフセット位置までのすべてのコンテンツが設定され、新規作成された同じ種類のノードには残りのテキストが設定されます。新しく作成されたノードは呼び出し元に返されます。元のノードに親があった場合、新しいノードは元のノードの次の兄弟として挿入されます。オフセットが元のノードの長さと等しい場合、新しく作成されたノードにはデータがありません。</p> + +<p>分割されたテキストノードは、 {{domxref("Node.normalize()")}} メソッドを用いて結合することができます。</p> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="syntaxbox notranslate"><var>newNode</var> = <var>textNode</var>.splitText(<var>offset</var>) +</pre> + +<h3 id="Parameters" name="Parameters">引数</h3> + +<dl> + <dt><code><var>offset</var></code></dt> + <dd>テキストノードを分割する直前の位置。</dd> +</dl> + +<h3 id="Return_value" name="Return_value">返値</h3> + +<p>新しく生成された {{domxref("Text")}} ノードを返し、指定されたオフセット位置移行のテキストが格納されます。</p> + +<h3 id="Exceptions" name="Exceptions">例外</h3> + +<p>{{domxref("DOMException")}} で値が <code>INDEX_SIZE_ERR</code> のものは、指定されたオフセットが負の値であるか、ノードのテキストの16ビット単位の文字数よりも大きい場合に発生します。 {{domxref("DOMException")}} で値が <code>NO_MODIFICATION_ALLOWED_ERR</code> のものは、ノードが読取専用の場合に発生します。</p> + +<h2 id="Example" name="Example">例</h2> + +<p>この例では、 {{HTMLElement("p")}} のテキストが二つのテキストノードに分割され、 {{HTMLElement("u")}} がその間に挿入されます。</p> + +<h3 id="HTML">HTML</h3> + +<pre class="brush: html notranslate"><p>foobar</p></pre> + +<h3 id="JavaScript">JavaScript</h3> + +<pre class="brush: js notranslate">const p = document.querySelector('p'); + +// <p> の中身をテキストノードとして取得 +const foobar = p.firstChild; + +// 'foobar' を二つのテキストノード 'foo' と 'bar' に分割し、 +// 'bar' を const として保存 +const bar = foobar.splitText(3); + +// <u> 要素を作成して ' new content ' を含める +const u = document.createElement('u'); +u.appendChild(document.createTextNode(' new content ')); + +// <u> を 'bar' の前に追加 +p.insertBefore(u, bar); + +// 結果: <p>foo<u> new content </u>bar</p></pre> + +<h3 id="Result" name="Result">結果</h3> + +<p>{{EmbedLiveSample("Example", 700, 70)}}</p> + +<h2 id="Specifications" name="Specifications">仕様書</h2> + +<table class="standard-table"> + <thead> + <tr> + <th scope="col">仕様書</th> + <th scope="col">状態</th> + <th scope="col">備考</th> + </tr> + </thead> + <tbody> + <tr> + <td>{{SpecName('DOM WHATWG', '#dom-text-splittext', 'Text.splitText')}}</td> + <td>{{Spec2('DOM WHATWG')}}</td> + <td>{{SpecName('DOM3 Core')}} から変更なし。</td> + </tr> + <tr> + <td>{{SpecName('DOM3 Core', 'core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM3 Core')}}</td> + <td>{{SpecName('DOM2 Core')}} から変更なし。</td> + </tr> + <tr> + <td>{{SpecName('DOM2 Core', 'core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM2 Core')}}</td> + <td>{{SpecName('DOM1')}} から変更なし。</td> + </tr> + <tr> + <td>{{SpecName('DOM1', 'level-one-core.html#ID-38853C1D', 'Text.splitText')}}</td> + <td>{{Spec2('DOM1')}}</td> + <td>初回定義</td> + </tr> + </tbody> +</table> + +<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2> + +<p class="hidden">このページの互換性一覧表は構造化データから生成されています。データに協力していただけるのであれば、 <a class="external" href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> をチェックアウトしてプルリクエストを送信してください。</p> + +<p>{{Compat("api.Text.splitText")}}</p> + +<h2 id="See_also" name="See_also">関連情報</h2> + +<ul> + <li>所属先の {{domxref("Text")}} インターフェイス</li> + <li>逆のメソッド: {{domxref("Node.normalize")}}</li> +</ul> |