diff options
Diffstat (limited to 'files/ja/web/api/resizeobserver')
-rw-r--r-- | files/ja/web/api/resizeobserver/index.html | 89 | ||||
-rw-r--r-- | files/ja/web/api/resizeobserver/resizeobserver/index.html | 86 |
2 files changed, 175 insertions, 0 deletions
diff --git a/files/ja/web/api/resizeobserver/index.html b/files/ja/web/api/resizeobserver/index.html new file mode 100644 index 0000000000..84e0d89431 --- /dev/null +++ b/files/ja/web/api/resizeobserver/index.html @@ -0,0 +1,89 @@ +--- +title: ResizeObserver +slug: Web/API/ResizeObserver +tags: + - API + - Experimental + - ResizeObserver + - インターフェイス + - オブザーバー + - コンテンツボックス + - バウンディングボックス + - リサイズオブザーバー API + - リファレンス +translation_of: Web/API/ResizeObserver +--- +<div>{{APIRef("Resize Observer API")}}{{SeeCompatTable}}</div> + +<p class="summary"><strong><code>ResizeObserver</code></strong> インターフェイスは、{{domxref('Element')}} のコンテンツ矩形または {{domxref('SVGElement')}} のバウンディングボックスへの変更を監視します。コンテンツ矩形は、コンテンツを配置できるボックスです。つまり、ボーダーボックスからパディングを引いたものです。(ボーダーとパディングの説明は<a href="/ja/docs/Learn/CSS/Introduction_to_CSS/Box_model">ボックスモデル</a>を見てください。)</p> + +<p>ResizeObserver は、無限のコールバックループとそれ自身のコールバック関数でサイズ変更することによって生じるであろう循環的な依存関係を避けます。これは、後続のフレームで DOM のより深い要素のみを処理することによって行われます。実装が仕様に従っている場合は、描画の前およびレイアウトの後にリサイズイベントを呼び出す必要があります。</p> + +<h2 id="コンストラクター">コンストラクター</h2> + +<dl> + <dt>{{domxref("ResizeObserver.ResizeObserver", "ResizeObserver()")}}</dt> + <dd>新しい <code>ResizeObserver</code> オブジェクトを作成して返します。</dd> +</dl> + +<h2 id="プロパティ">プロパティ</h2> + +<p>なし</p> + +<h3 id="イベントハンドラー">イベントハンドラー</h3> + +<p>なし</p> + +<h2 id="メソッド">メソッド</h2> + +<dl> + <dt>{{domxref('ResizeObserver.disconnect()')}}</dt> + <dd>監視対象のすべての {{domxref('Element')}} ターゲットの監視を終了します。</dd> + <dt>{{domxref('ResizeObserver.observe()')}}</dt> + <dd>指定された {{domxref('Element')}} の監視を開始します。</dd> + <dt>{{domxref('ResizeObserver.unobserve()')}}</dt> + <dd>指定された {{domxref('Element')}} の監視を終了します。</dd> +</dl> + +<h2 id="例">例</h2> + +<p>次の例では、幅の変更に応じてボックスの境界線の半径を変更します。</p> + +<pre class="brush: js">const resizeObserver = new ResizeObserver(entries => { + for (let entry of entries) { + entry.target.style.borderRadius = Math.max(0, 250 - entry.contentRect.width) + 'px'; + } +}); +resizeObserver.observe(document.querySelector('.box:nth-child(2)'));</pre> + +<h2 id="仕様">仕様</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">仕様書</th> + <th scope="col">ステータス</th> + <th scope="col">コメント</th> + </tr> + <tr> + <td>{{SpecName('Resize Observer','#resize-observer-interface','ResizeObserver')}}</td> + <td>{{Spec2('Resize Observer')}}</td> + <td>初期定義</td> + </tr> + </tbody> +</table> + +<h2 id="ブラウザの互換性">ブラウザの互換性</h2> + +<div class="hidden">このページの互換性テーブルは構造化データから生成されます。データに貢献したい場合は <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> をチェックして、プルリクエストを送ってください。</div> + +<p>{{Compat("api.ResizeObserver")}}</p> + +<h2 id="あわせて参照">あわせて参照</h2> + +<ul> + <li><a href="/ja/docs/Learn/CSS/Introduction_to_CSS/Box_model">ボックスモデル</a></li> + <li>{{domxref('PerformanceObserver')}}</li> + <li>{{domxref('MutationObserver')}}</li> + <li>{{domxref('IntersectionObserver')}} (<a href="/ja/docs/Web/API/Intersection_Observer_API">Intersection Observer API</a> の一部)</li> +</ul> diff --git a/files/ja/web/api/resizeobserver/resizeobserver/index.html b/files/ja/web/api/resizeobserver/resizeobserver/index.html new file mode 100644 index 0000000000..6cb3e3938c --- /dev/null +++ b/files/ja/web/api/resizeobserver/resizeobserver/index.html @@ -0,0 +1,86 @@ +--- +title: ResizeObserver.ResizeObserver() +slug: Web/API/ResizeObserver/ResizeObserver +tags: + - API + - Experimental + - ResizeObserver + - オブザーバー + - コンストラクター + - リサイズオブザーバー API + - リファレンス +translation_of: Web/API/ResizeObserver/ResizeObserver +--- +<div>{{APIRef("Resize Observer API")}}</div> + +<p class="summary"><strong><code>ResizeObserver</code></strong> コンストラクターは、 {{domxref('Element')}} のコンテンツまたは境界の矩形、または {{domxref('SVGElement')}} のバウンディングボックスに対する変更を監視する新しい {{domxref("ResizeObserver")}} オブジェクトを作成します。</p> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="syntaxbox">var <var>ResizeObserver</var> = new ResizeObserver(<var>callback</var>)</pre> + +<h3 id="Parameters" name="Parameters">引数</h3> + +<dl> + <dt><code><var>callback</var></code></dt> + <dd>監視中のものに寸法の変更が発生するたびに呼び出される関数です。関数は2つの引数で呼び出されます。 + <dl> + <dt><code><var>entries</var></code></dt> + <dd>{{domxref('ResizeObserverEntry')}} オブジェクトの配列で、それぞれの変更の後で要素の新しい寸法にアクセスするために使用することができます。</dd> + <dt><code><var>observer</var></code></dt> + <dd><code>ResizeObserver</code> 自身への参照で、必要に応じてコールバック内から確実にアクセスできます。これは、たとえば特定の条件に達したときにオブザーバーを自動的に監視解除するために使用できますが、必要ない場合は省略することができます。</dd> + </dl> + + <p>コールバックは一般に、次のパターンに従います。</p> + + <pre class="brush: js">function(entries, observer) { + for (let entry of entries) { + // Do something to each entry + // and possibly something to the observer itself + } +}</pre> + </dd> +</dl> + +<h2 id="Examples" name="Examples">例</h2> + +<p>次のスニペットは <a href="https://mdn.github.io/dom-examples/resize-observer/resize-observer-text.html">resize-observer-text.html</a> (<a href="https://github.com/mdn/dom-examples/blob/master/resize-observer/resize-observer-text.html">ソースを表示</a>) の例から取ったものです。</p> + +<pre class="brush: js">const resizeObserver = new ResizeObserver(entries => { + for (let entry of entries) { + if(entry.contentBoxSize) { + h1Elem.style.fontSize = Math.max(1.5, entry.contentBoxSize.inlineSize/200) + 'rem'; + pElem.style.fontSize = Math.max(1, entry.contentBoxSize.inlineSize/600) + 'rem'; + } else { + h1Elem.style.fontSize = Math.max(1.5, entry.contentRect.width/200) + 'rem'; + pElem.style.fontSize = Math.max(1, entry.contentRect.width/600) + 'rem'; + } + } +}); + +resizeObserver.observe(divElem);</pre> + +<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('Resize Observer','#dom-resizeobserver-resizeobserver-callback-callback','ResizeObserver')}}</td> + <td>{{Spec2('Resize Observer')}}</td> + <td>初回定義</td> + </tr> + </tbody> +</table> + +<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2> + +<div class="hidden">このページの互換性一覧表は構造化データから生成されています。データに協力していただけるのであれば、 <a class="external" href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> をチェックアウトしてプルリクエストを送信してください。</div> + +<p>{{Compat("api.ResizeObserver.ResizeObserver")}}</p> |