このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

CSS font-width プロパティ

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Experimental: これは実験的な機能です。
本番で使用する前にブラウザー互換性一覧表をチェックしてください。

メモ: font-width プロパティは、古い別名である font-stretch の新しい置き換えです。font-width は仕様書の推奨される名前ですが、font-stretch のほうが今のところより広くブラウザーが対応しています。詳しくはフォールバックの例ブラウザーの互換性の表を参照してください。

font-widthCSS のプロパティで、フォントから通常、圧縮、引き伸ばしのフェイスを選択します。

試してみましょう

font-width: condensed;
font-width: expanded;
font-width: ultra-expanded;
font-width: 50%;
font-width: 100%;
font-width: 150%;
<section class="default-example" id="default-example">
  <p class="transition-all" id="example-element">
    London. Michaelmas term lately over, and the Lord Chancellor sitting in
    Lincoln's Inn Hall. Implacable November weather. As much mud in the streets
    as if the waters had but newly retired from the face of the earth, and it
    would not be wonderful to meet a Megalosaurus, forty feet long or so,
    waddling like an elephantine lizard up Holborn Hill.
  </p>
</section>
@font-face {
  src: url("/shared-assets/fonts/LeagueMono-VF.ttf") format("truetype");
  font-family: "League";
  font-style: normal;
  font-weight: normal;
}

section {
  font-size: 1.2em;
  font-family: "League", sans-serif;
}

構文

css
/* キーワード値 */
font-width: normal;
font-width: ultra-condensed;
font-width: extra-condensed;
font-width: condensed;
font-width: semi-condensed;
font-width: semi-expanded;
font-width: expanded;
font-width: extra-expanded;
font-width: ultra-expanded;

/* パーセント値 */
font-width: 50%;
font-width: 100%;
font-width: 200%;

/* グローバル値 */
font-width: inherit;
font-width: initial;
font-width: revert;
font-width: revert-layer;
font-width: unset;

このプロパティは、単一のキーワードまたは単一の <percentage> 値として指定することができます。

normal

通常体のフォントフェイスを指定します。

semi-condensed, condensed, extra-condensed, ultra-condensed

通常より幅を圧縮した (condensed) フォントフェイスを指定します。最も幅の狭いフェイスは ultra-condensed です。

semi-expanded, expanded, extra-expanded, ultra-expanded

通常より幅を引き伸ばした (expanded) フォントフェイスを指定します。最も幅の広いフェイスは ultra-expanded です。

<percentage>

<percentage> 値で、50% 以上 200% 以下です。このプロパティでは負の数は許可されていません。

キーワードと数値の対応

キーワード値と数値によるパーセント値の対応は、次の表のとおりです。

キーワード パーセント値
ultra-condensed 50%
extra-condensed 62.5%
condensed 75%
semi-condensed 87.5%
normal 100%
semi-expanded 112.5%
expanded 125%
extra-expanded 150%
ultra-expanded 200%

解説

フォントファミリーによっては、通常より狭い文字(圧縮したフェイス)、通常より広い文字(引き伸ばしたフェイス)などの追加のフェイスを提供しています。

font-width を使うと、そのようなフォントで圧縮したフェイスや引き伸ばしたフェイスを選択することができます。使用しているフォントが圧縮したフェイスや引き伸ばしたフェイスを提供していない場合は、このプロパティは効果がありません。

フォントフェイスの選択

font-width で与えられた値で選択されるフェイスは、フォントがそのフェイスに対応しているかによります。与えられた値に正確に一致するフェイスがフォントに存在しない場合、値が 100% よりも小さい場合は圧縮したフェイスが割り当てられ、100% 以上の場合はより引き伸ばしたフェイスが割り当てられます。

以下の表は 2 つの異なるフォントにおいて、font-width に様々なパーセント値を設定した場合の効果を示しています。

ブラウザーが font-width プロパティに対応していない場合に備え、上の表がどのように表示されるかを以下のスクリーンショットに示します。

小文字の "e" を異なる幅(50%、62.5%、75%、87.5%、100%、112.5%、125%、150%、200%)で表示させた 2 行の比較表。上段は Inconsolata、下段は Anek Malayalam とラベル付けされています。どちらもサンセリフフォントですが、Inconsolata の文字は Anek Malayalam に比べてわずかに幅広くなっています。

  • Inconsolata は、 50% から 200% まで連続的に幅を変化させることができる可変フォントです。
  • Anek Malayalam は 75% から 125% の幅に対応している可変の Google フォントです。この範囲を下回る値や上回る値では、最も一致するフォントが選択されます。

公式定義

初期値normal
適用対象すべての要素とテキスト。 ::first-letterおよび::first-line にも適用されます。
継承あり
計算値percentage
アニメーションの種類計算値の型による

形式文法

font-width = 
normal |
<percentage [0,∞]> |
ultra-condensed |
extra-condensed |
condensed |
semi-condensed |
semi-expanded |
expanded |
extra-expanded |
ultra-expanded
この構文は CSS Fonts Module Level 4 による最新の標準を反映しています。すべてのブラウザーがすべての部分を実装しているわけではありません。サポート情報についてはブラウザーの互換性を参照してください。

フォントの幅のパーセント値の設定

html
<p class="condensed">an elephantine lizard</p>
<p class="normal">an elephantine lizard</p>
<p class="expanded">an elephantine lizard</p>
css
@font-face {
  src: url("/shared-assets/fonts/LeagueMono-VF.ttf") format("truetype");
  font-family: "LeagueMonoVariable";
  font-style: normal;
}

p {
  font:
    1.5rem "LeagueMonoVariable",
    sans-serif;
}

.condensed {
  font-width: 50%;
}

.normal {
  font-width: 100%;
}

.expanded {
  font-width: 200%;
}

font-stretch による代替の提供

font-width はまだブラウザーの対応が広くないため、代替手段として古い font-stretch プロパティを追加することをお勧めします。対応しているブラウザーが新しいプロパティを使用するように、font-stretchfont-width の前に記載してください。

css
p {
  font-stretch: condensed; /* font-width に対応していないブラウザー向け */
  font-width: condensed;
}

メモ: この代替パターンについては、PostCSS 用の postcss-preset-env プラグインを使用することで自動化できます。このプラグインには、postcss-font-width-property 変換機能が含まれており、font-width プロパティを自動的に font-stretch に変換します。

仕様書

Specification
CSS Fonts Module Level 4
# propdef-font-width

ブラウザーの互換性

関連情報