diff options
Diffstat (limited to 'files/ja/web/css/break-after')
-rw-r--r-- | files/ja/web/css/break-after/index.md | 309 |
1 files changed, 127 insertions, 182 deletions
diff --git a/files/ja/web/css/break-after/index.md b/files/ja/web/css/break-after/index.md index 2c4374e1be..30c81c89e0 100644 --- a/files/ja/web/css/break-after/index.md +++ b/files/ja/web/css/break-after/index.md @@ -3,19 +3,20 @@ title: break-after slug: Web/CSS/break-after tags: - CSS - - CSS Fragmentation - - CSS Multi-column Layout - - CSS Property - - NeedsExample - - Reference - - 'recipe:css-property' + - CSS 断片化 + - CSS 段組みレイアウト + - CSS プロパティ + - リファレンス + - recipe:css-property +browser-compat: css.properties.break-after translation_of: Web/CSS/break-after --- -<div>{{CSSRef}}</div> +{{CSSRef}} -<p><strong><code>break-after</code></strong> は <a href="/ja/docs/Web/CSS">CSS</a> のプロパティで、生成されたボックスの後で、ページ、段、領域をどのように区切るかを設定します。ボックスが生成されない場合は、このプロパティは無視されます。</p> +**`break-after`** は [CSS](/ja/docs/Web/CSS) のプロパティで、生成されたボックスの後で、ページ、段、領域をどのように区切るかを設定します。ボックスが生成されない場合は、このプロパティは無視されます。 -<pre class="brush:css no-line-numbers notranslate">/* 一般の区切り値 */ +```css +/* 一般の区切り値 */ break-after: auto; break-after: avoid; break-after: always; @@ -40,154 +41,123 @@ break-after: region; /* グローバル値 */ break-after: inherit; break-after: initial; +break-after: revert; break-after: unset; -</pre> - -<p>区切り位置になる可能性のある場所 (言い換えれば、要素の境界) は、三つのプロパティに影響されます。前の要素の <code>break-after</code> の値、次の要素の {{cssxref("break-before")}} の値、包含要素の {{cssxref("break-inside")}} の値です。</p> - -<p>区切られるかどうかを判断するために、以下の規則が適用されます。</p> - -<ol> - <li>考慮される三つの値の中の何れかに<em>区切りを強制する値</em> (<code>always</code>, <code>left</code>, <code>right</code>, <code>page</code>, <code>column</code>, <code>region</code> の何れか) がある場合、それが優先されます。そのような区切りが複数ある場合は、フローの中で最も後に現れる要素のものが使用されます (つまり、 <code>break-before</code> の値は <code>break-after</code> の値より優先し、それは更に <code>break-inside</code> よりも優先します)。</li> - <li>考慮される三つの値の中に<em>区切りを防止する値</em> (<code>avoid</code>, <code>avoid-page</code>, <code>avoid-region</code>, <code>avoid-column</code> の何れか) が含まれていた場合は、その場所で区切りは適用されません。</li> -</ol> - -<p>強制的な区切りが適用されると、必要に応じてソフトな区切りが追加される場合がありますが、 <code>avoid</code> に関する値に解決される要素の境界には追加されません。</p> - -<h2 id="Syntax" name="Syntax">構文</h2> - -<p><code>break-after</code> プロパティは、以下の一覧にあるキーワード値のうちの一つで指定します。</p> - -<h3 id="Values" name="Values">値</h3> - -<h4 id="Generic_break_values" name="Generic_break_values">一般の区切り値</h4> - -<dl> - <dt><code>auto</code></dt> - <dd>該当するボックスの直後に何らかの (ページ、段、領域の) 区切りを挿入することを許可しますが、強制はしません。</dd> - <dt><code>avoid</code></dt> - <dd>該当するボックスの直後に何らかの (ページ、段、領域の) 区切りを挿入することを禁止します。</dd> - <dt><code>always</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後で強制的に改ページを行います。この区切りの種類は断片化のコンテキストを直接含むものです。段組みコンテナーの中であれば強制的な段区切りとなり、ページ付きメディアの (ただし段組みコンテナーの中ではない) 場合はページ区切りになります。</dd> - <dt><code>all</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後で強制的に改ページを行います。すべての分断しうるコンテキストを通して区切ります。よって、段組みコンテナーの中での区切りは、ページコンテナーの中であれば強制的に段組みとページを区切ります。</dd> -</dl> - -<h4 id="Page_break_values" name="Page_break_values">改ページ値</h4> - -<dl> - <dt><code>avoid-page</code></dt> - <dd>該当するボックスの直後の改ページを禁止します。</dd> - <dt><code>page</code></dt> - <dd>該当するボックスの直後で改ページを行います。</dd> - <dt><code>left</code></dt> - <dd>該当するボックスの直後で一つまたは二つの改ページを行い、次のページが左ページになるようにします。</dd> - <dt><code>right</code></dt> - <dd>該当するボックスの直後で一つまたは二つの改ページを行い、次のページが右ページになるようにします。</dd> - <dt><code>recto</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後で一つまたは二つの改ページを行い、次のページが奇数ページになるようにします。 (奇数ページは左から右に開く場合は右ページになり、右から左に開く場合は左ページになります。)</dd> - <dt><code>verso</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後で一つまたは二つの改ページを行い、次のページが偶数ページになるようにします。 (奇数ページは左から右に開く場合は左ページになり、右から左に開く場合は右ページになります。)</dd> -</dl> - -<h4 id="Column_break_values" name="Column_break_values">段区切り値</h4> - -<dl> - <dt><code>avoid-column</code></dt> - <dd>該当するボックスの直後の段区切りを禁止します。</dd> - <dt><code>column</code></dt> - <dd>該当するボックスの直後で段区切りを行います。</dd> -</dl> - -<h4 id="領域区切り値">領域区切り値</h4> - -<dl> - <dt><code>avoid-region</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後の領域区切りを禁止します。</dd> - <dt><code>region</code> {{experimental_inline}}</dt> - <dd>該当するボックスの直後で領域区切りを行います。</dd> -</dl> - -<h2 id="Page_break_aliases" name="Page_break_aliases">改ページの別名</h2> - -<p>互換性のため、古い {{cssxref("page-break-after")}} はブラウザーから <code>break-after</code> の別名として扱われます。これにより、 <code>page-break-after</code> を使用しているサイトが引き続き設計通りに動作することを保証します。値のサブセットは次のような別名になります。</p> - -<table> - <thead> - <tr> - <th scope="col">page-break-after</th> - <th scope="col">break-after</th> - </tr> - </thead> - <tbody> - <tr> - <td><code>auto</code></td> - <td><code>auto</code></td> - </tr> - <tr> - <td><code>left</code></td> - <td><code>left</code></td> - </tr> - <tr> - <td><code>right</code></td> - <td><code>right</code></td> - </tr> - <tr> - <td><code>avoid</code></td> - <td><code>avoid</code></td> - </tr> - <tr> - <td><code>always</code></td> - <td><code>page</code></td> - </tr> - </tbody> -</table> - -<div class="blockIndicator note"> -<p>ブラウザーにおいては <code>always</code> の値は <code>page-break-*</code> において、段区切りではなくページ区切りとして実装されています。したがって、 Level 4 の仕様書では <code>always</code> の値ではなく <code>page</code> の別名となっています。</p> -</div> - -<h2 id="Formal_definition" name="Formal_definition">公式定義</h2> - -<p>{{cssinfo}}</p> - -<h2 id="Formal_syntax" name="Formal_syntax">形式文法</h2> +``` + +区切り位置になる可能性のある場所 (言い換えれば、要素の境界) は、3 つのプロパティに影響されます。前の要素の `break-after` の値、次の要素の {{cssxref("break-before")}} の値、包含要素の {{cssxref("break-inside")}} の値です。 + +分割が行われるかどうかを判断するためには、以下の規則が適用されます。 + +1. 考慮される 3 つの値の中の何れかに*区切りを強制する値* (`always`, `left`, `right`, `page`, `column`, `region` の何れか) がある場合、それが優先されます。そのような区切りが複数ある場合は、フローの中で最も後に現れる要素のものが使用されます (つまり、 `break-before` の値は `break-after` の値より優先し、それは更に `break-inside` よりも優先します)。 +2. 考慮される 3 つの値の中に*区切りを防止する値* (`avoid`, `avoid-page`, `avoid-region`, `avoid-column` の何れか) が含まれていた場合は、その場所で区切りは適用されません。 + +強制的な区切りが適用されると、必要に応じてソフトな区切りが追加される場合がありますが、 `avoid` に関する値に解決される要素の境界には追加されません。 + +## 構文 + +`break-after` プロパティは、以下の一覧にあるキーワード値のうちの一つで指定します。 + +### 値 + +### 一般の区切り値 + +- `auto` + - : 該当するボックスの直後に何らかの (ページ、段、領域の) 区切りを挿入することを許可しますが、強制はしません。 +- `avoid` + - : 該当するボックスの直後に何らかの (ページ、段、領域の) 区切りを挿入することを禁止します。 +- `always` {{experimental_inline}} + - : 該当するボックスの直後で強制的に改ページを行います。この区切りの種類は断片化のコンテキストを直接含むものです。段組みコンテナーの中であれば強制的な段区切りとなり、ページ付きメディアの (ただし段組みコンテナーの中ではない) 場合はページ区切りになります。 +- `all` {{experimental_inline}} + - : 該当するボックスの直後で強制的に改ページを行います。すべての分断しうるコンテキストを通して区切ります。よって、段組みコンテナーの中での区切りは、ページコンテナーの中であれば強制的に段組みとページを区切ります。 + +#### 改ページ値 + +- `avoid-page` + - : 該当するボックスの直後の改ページを禁止します。 +- `page` + - : 該当するボックスの直後で改ページを行います。 +- `left` + - : 該当するボックスの直後で一つまたは二つの改ページを行い、次のページが左ページになるようにします。 +- `right` + - : 該当するボックスの直後で一つまたは二つの改ページを行い、次のページが右ページになるようにします。 +- `recto` {{experimental_inline}} + - : 該当するボックスの直後で一つまたは二つの改ページを行い、次のページが奇数ページになるようにします。 (奇数ページは左から右に開く場合は右ページになり、右から左に開く場合は左ページになります。) +- `verso` {{experimental_inline}} + - : 該当するボックスの直後で一つまたは二つの改ページを行い、次のページが偶数ページになるようにします。 (奇数ページは左から右に開く場合は左ページになり、右から左に開く場合は右ページになります。) + +#### 段区切り値 + +- `avoid-column` + - : 該当するボックスの直後の段区切りを禁止します。 +- `column` + - : 該当するボックスの直後で段区切りを行います。 + +#### 領域区切り値 + +- `avoid-region` {{experimental_inline}} + - : 該当するボックスの直後の領域区切りを禁止します。 +- `region` {{experimental_inline}} + - : 該当するボックスの直後で領域区切りを行います。 + +## 改ページの別名 + +互換性のため、古い {{cssxref("page-break-after")}} はブラウザーから `break-after` の別名として扱われます。これにより、 `page-break-after` を使用しているサイトが引き続き設計通りに動作することを保証します。値のサブセットは次のような別名になります。 + +| page-break-after | break-after | +| ---------------- | ----------- | +| `auto` | `auto` | +| `left` | `left` | +| `right` | `right` | +| `avoid` | `avoid` | +| `always` | `page` | + +> **Note:** ブラウザーにおいては `always` の値は `page-break-*` において、段区切りではなくページ区切りとして実装されています。したがって、 Level 4 の仕様書では `always` の値ではなく `page` の別名となっています。 + +## 公式定義 + +{{cssinfo}} + +## 形式文法 {{csssyntax}} -<h2 id="Examples" name="Examples">例</h2> +## 例 -<h3 id="Breaking_into_neat_columns" name="Breaking_into_neat_columns">きれいに段に分割</h3> +### きれいに段に分割 -<p>次の例では、すべての段にまたがる <code><h1></code> (<code>column-span: all</code> を使用して実現) と、一連の <code><h2></code> と段落を <code>column-width: 200px</code> を使用して段組みレイアウトしたコンテナーを用意しています。</p> +次の例では、すべての段にまたがる `<h1>` (`column-span: all` を使用して実現) と、一連の `<h2>` と段落を `column-width: 200px` を使用して段組みレイアウトしたコンテナーを用意しています。 -<p>既定では、小見出しと段落は、見出しの位置が統一されていないため、かなり乱雑にレイアウトされていました。しかし、 <code>break-after: column</code> を <code><p></code> 要素に使うことで、それぞれの要素の後に強制的に改行するようにしたので、各段の先頭に <code><h2></code> がきちんと配置されます。</p> +既定では、小見出しと段落は、見出しの位置が統一されていないため、かなり乱雑にレイアウトされていました。しかし、 `break-after: column` を `<p>` 要素に使うことで、それぞれの要素の後に強制的に改行するようにしたので、各段の先頭に `<h2>` がきちんと配置されます。 -<h4 id="HTML">HTML</h4> +#### HTML -<pre class="brush: html notranslate"><article> - <h1>Main heading</h1> +```html +<article> + <h1>大見出し</h1> - <h2>Subheading</h2> + <h2>小見出し</h2> - <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla vitae fringilla mauris. Quisque commodo eget nisi sed pretium. Mauris luctus nec lacus in ultricies. Mauris vitae hendrerit arcu, ac scelerisque lacus. Aliquam lobortis in lacus sit amet posuere. Fusce iaculis urna id neque dapibus, eu lacinia lectus dictum.</p> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla vitae fringilla mauris. Quisque commodo eget nisi sed pretium. Mauris luctus nec lacus in ultricies. Mauris vitae hendrerit arcu, ac scelerisque lacus. Aliquam lobortis in lacus sit amet posuere. Fusce iaculis urna id neque dapibus, eu lacinia lectus dictum.</p> - <h2>Subheading</h2> + <h2>小見出し</h2> - <p>Praesent condimentum dui dui, sit amet rutrum diam tincidunt eu. Cras suscipit porta leo sit amet rutrum. Sed vehicula ornare tincidunt. Curabitur a ipsum ac diam mattis volutpat ac ut elit. Nullam luctus justo non vestibulum gravida. Morbi metus libero, pharetra non porttitor a, molestie nec nisi.</p> + <p>Praesent condimentum dui dui, sit amet rutrum diam tincidunt eu. Cras suscipit porta leo sit amet rutrum. Sed vehicula ornare tincidunt. Curabitur a ipsum ac diam mattis volutpat ac ut elit. Nullam luctus justo non vestibulum gravida. Morbi metus libero, pharetra non porttitor a, molestie nec nisi.</p> - <h2>Subheading</h2> + <h2>小見出し</h2> - <p>Vivamus eleifend metus vitae neque placerat, eget interdum elit mattis. Donec eu vulputate nibh. Ut turpis leo, malesuada quis nisl nec, volutpat egestas tellus. + <p>Vivamus eleifend metus vitae neque placerat, eget interdum elit mattis. Donec eu vulputate nibh. Ut turpis leo, malesuada quis nisl nec, volutpat egestas tellus. - <h2>Subheading</h2> + <h2>小見出し</h2> - <p>In finibus viverra enim vel suscipit. Quisque consequat velit eu orci malesuada, ut interdum tortor molestie. Proin sed pellentesque augue. Nam risus justo, faucibus non porta a, congue vel massa. Cras luctus lacus nisl, sed tincidunt velit pharetra ac. Duis suscipit faucibus dui sed ultricies.</p> -</article></pre> + <p>In finibus viverra enim vel suscipit. Quisque consequat velit eu orci malesuada, ut interdum tortor molestie. Proin sed pellentesque augue. Nam risus justo, faucibus non porta a, congue vel massa. Cras luctus lacus nisl, sed tincidunt velit pharetra ac. Duis suscipit faucibus dui sed ultricies.</p> +</article> +``` -<h4 id="CSS">CSS</h4> +#### CSS -<pre class="brush: css notranslate">html { +```css +html { font-family: helvetica, arial, sans-serif; } @@ -211,47 +181,22 @@ p { article { column-width: 200px; gap: 20px; -}</pre> - -<h3 id="Result" name="Result">結果</h3> - -<p>{{EmbedLiveSample('Breaking_into_neat_columns', '100%', 600)}}</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('CSS3 Fragmentation', '#break-between', 'break-after')}}</td> - <td>{{Spec2('CSS3 Fragmentation')}}</td> - <td><code>recto</code> および <code>verso</code> キーワードを追加。このプロパティのメディア種別を <code>paged</code> から {{xref_cssvisual}} に変更。異なる種類の区切りを持つ区切りアルゴリズムを定義した。</td> - </tr> - <tr> - <td>{{SpecName('CSS3 Regions', '#region-flow-break', 'break-after')}}</td> - <td>{{Spec2('CSS3 Regions')}}</td> - <td>領域区切りを扱うようにプロパティを拡張した。 <code>avoid-region</code> および <code>region</code> キーワードを追加した。</td> - </tr> - <tr> - <td>{{SpecName('CSS3 Multicol', '#break-before-break-after-break-inside', 'break-after')}}</td> - <td>{{Spec2('CSS3 Multicol')}}</td> - <td>初回定義。 CSS 2.1 の {{cssxref("page-break-after")}} プロパティを拡張し、ページ区切りと段区切りの両方を扱うようにした。</td> - </tr> - </tbody> -</table> - -<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2> - -<h3 id="Support_in_multi-column_layout" name="Support_in_multi-column_layout">段組みレイアウトでの対応</h3> - -<p>{{Compat("css.properties.break-after.multicol_context")}}</p> - -<h3 id="Support_in_paged_media" name="Support_in_paged_media">ページメディアでの対応</h3> - -<p>{{Compat("css.properties.break-after.paged_context")}}</p> +} +``` + +### 結果 + +{{EmbedLiveSample('Breaking_into_neat_columns', '100%', 600)}} + +## 仕様書 + +{{Specifications("css.properties.break-after.multicol_context")}} + +## ブラウザーの互換性 + +{{Compat}} + +## 関連情報 + +- [段組みレイアウト](/ja/docs/Learn/CSS/CSS_layout/Multiple-column_Layout) +- [Breaking Boxes With CSS Fragmentation](https://www.smashingmagazine.com/2019/02/css-fragmentation/) |