モジュール化の構築に関する前の 2 つの記事では、rem & em とレスポンシブ タイポグラフィについて説明しました。記事のコメントでは、ビューポート単位に基づく Web ページのレイアウトについて多くの熱意がありました。想像力の余地が大きい。
ビューポート単位には計算が含まれるため、しばらくの間、仕事でビューポート単位を使用することに抵抗がありました。しかし、つい先週、私は抵抗を克服し、Web レイアウトでのビューポート ユニットの使用法を理解し始めました。ビューポート ユニットとそれが Web ページ レイアウトでどのように機能するかを詳しく説明する前に、まず一般的なビューポート ユニットとは何かを理解しましょう。
CSS 仕様では、次の 4 種類のビューポート単位が使用できます。
ビューポート、つまりブラウザの画面サイズ。1vw はブラウザの幅の 1% に等しく、100vw はブラウザ全体の幅です。
ビューポートの単位サイズは、ページの読み込み時、ページのズーム時、またはビューポート サイズの変更に基づいて自動的に計算されます。画面の向きが変わります(横→縦切り替え)。このため、常にビューポートの 4 分の 1 のサイズのコンテナを作成するのは非常に簡単です。
.component { width: 50vw; height: 50vh; background: rgba(255, 0, 0, 0.25)}
Web ページのレイアウトにビューポート ユニットを使用する唯一の理由は、ビューポート ユニット サイズがクライアント ブラウザのビューポート サイズに基づいて自動的に計算されるためです。つまり、メディア クエリを通じてフォント サイズを明示的に宣言する必要はありません。デモを使って簡単に説明しましょう。
コードは次のとおりです。ブレークポイントを 800px に設定し、フォント サイズを 16px から 20px に変更します。
// Note: CSS are all written in SCSShtml { font-size: 16px; @media (min-width: 800px) { font-size: 20px; }}
上記のコードでは、ビューポート サイズが 800px の場合、フォントは 16 ピクセルから 20 ピクセルに変化します。これはレスポンシブ タイポグラフィでは一般的なアプローチです。ページ レイアウトをすべてのデバイスに確実に適応させるために、ブレークポイント間にメディア クエリを追加するという問題が発生することがあります。
html { font-size: 16px; @media (min-width: 600px) { font-size: 18px; } @media (min-width: 800px) { font-size: 20px; }}
これは機能しますが、より具体的なメディア クエリのルールとフォント サイズが必要です。通常、フォント サイズは 3 ~ 4 が選択されます。
もちろん、それはあります。これがビューポート ユニットの目的です。フォント サイズをビューポート単位で表現できます:
html { font-size: 3vw; }
素晴らしいですね?短いコード部分が適応を実装します。ただし、明らかな欠点もあります。つまり、ビューポートのユニット サイズがデバイス画面のビューポート サイズに基づいて計算されるため、画面の小さなデバイス (幅 320 ピクセルの携帯電話など) ではフォントが小さすぎます。画面が大きいデバイス (幅 1440 ピクセルの携帯電話など) の場合、フォント サイズが非常に大きくなり、読みにくくなります。
さて、私たちが現在直面している興味深い課題は、ビューポート単位の計算におけるさまざまなデバイスのビューポート幅の影響をどのように解決するかということです。簡単な方法は、font-size の最小値を設定し、calc() 属性を使用して小さな画面デバイス上のフォント サイズ値を動的に計算することです。
html { font-size: calc(18px + 0.25vw) }
Mike Riethmuller のドキュメントを参照してください。レスポンシブ タイポグラフィの正確な制御
ただし、すべてのブラウザが calc() のこの計算方法 (px+vw) をサポートしているわけではありません。解決策も非常に簡単です。ブラウザのサポートを向上させるために、パーセントと vw を計算に使用します。
html { font-size: calc(112.5% + 0.5vw) }
克服すべき次の課題は、ビューポート単位を使用することです。 タイポグラフィのフォント サイズを設定するには要素 (h1 ~ h6)。
まず、
html { font-size: calc(112.5% + 0.25vw) }h1 { font-size: calc((112.5% + 0.25vw) * 2); }
HTML 要素のフォント サイズを 2 倍にしようとしましたが、うまくいきませんでした。
ビューポートの幅が 800 ピクセルであると仮定すると、デフォルトのフォント サイズは 16 ピクセルです。
HTML 要素の場合、112.5% はフォント サイズが 18 ピクセル (112.5/100) であることを意味します。 * 16px )
h1 要素の場合、112.5%つまり、 font-size は 22.5px(112.5/100 * 20px)
最初の方法は、単純に 112.5% を 100% に変更することです:
2 番目の方法は、フォント サイズが要素間で継承されないようにすることです:
h1 { font-size: calc((100% + 0.25vw) * 2) }
h1 { font-size: calc((100% + 0.25vw) * 2) }p { font-size: calc((100% + 0.25vw)) }
这两种方式看起来有点 hack,看起来不爽,于是又继续尝试其它方法。最终,最干净的方式是使用 Rem & Em :
html { font-size: calc(112.5% + 0.25vw) }h1 { font-size: 2em; }
既然讲到了字体大小的计算,那接下来的问题是: 视口单位的垂直和标准化计算是怎么样的?
这个相对比较容易回答。不知是否注意到,视口单位常仅被用于 html 元素?其它元素仍用 rem 和 em 作为计算的单位。
这就意味着,你仍然能使用 rem 和 em 用于视口单位的垂直和标准化计算,这和我之前在 Everything I Know about Responsive Typography 一文中讨论的一样。
结束这篇文章之前,最后一个需要谈到的问题是:要怎么样去计算 vw 的值,才能在视口宽度是 800px 时,排版的字体大小为 20px?很多人问到了这个问题,因而,将这个问题简化成一个词就是—精确。换句话说,如何才能字体大小更加精确?
结果是,Mike 已经替我解决了这个问题,我只需要再简单解释下计算方式。
假设你要处理下面两种情况:
首先,我们必须将较小的 font-size 值转为百分比。第一部计算是:calc(18/16 * 100%) (或者 calc(112.5%))。 接下来,计算出 vw 值。 这部分的计算略繁琐:
最终,结果如下:
html { font-size: calc(112.5% + 4 / 400 * (100vw - 600px) )}
开始接触可能会比较复杂,但是熟悉之后,你可以把它简化成 Sass 混入( simple sass mixin )。