ホームページ  >  記事  >  ウェブフロントエンド  >  CSS でのウィンドウ単位とパーセント単位の使用について

CSS でのウィンドウ単位とパーセント単位の使用について

不言
不言オリジナル
2018-06-26 15:13:061498ブラウズ

この記事ではCSSにおけるウィンドウ単位とパーセンテージ単位の使い方を中心に詳しく解説していますので、必要な方は参考にしてください

ビューポート単位は相対的な単位。つまり、客観的な寸法がありません。それらのサイズはビューポートのサイズによって決まります。ビューポートに関連するユニットは次の 4 つです。


最初の 2 つのユニットは使用される可能性が高いため、焦点を当てます。 2015812182921966.jpg (957×236)

多くの場合、ビューポート単位 (vh および vw) とパーセンテージ単位は、達成できることの点で重複します。ただし、それぞれに明確な長所と短所があります。要約すると:

幅を扱う場合は、% 単位の方が適切です。高さを扱う場合は、vh 単位の方が適しています。

全幅を占める要素: % > vw

前述したように、vw ユニットはビューポートの幅に基づいてサイズを決定します。ただし、ブラウザは、スクロール バーのスペースも含め、ブラウザ ウィンドウに基づいてウィンドウ サイズを計算します。


ページがビューポートの高さを超えている場合、スクロール バーが表示され、ビューポートの幅は HTML 要素の幅よりも大きくなります。 2015812183007643.jpg (1172×910)

Viewport > html > body

したがって、要素を 100vw に設定すると、この要素は html 要素と body 要素の範囲を超えます。この例では、html 要素を赤い枠線で囲み、セクション要素の背景色を設定します。


この微妙な違いのため、要素をページの幅全体に広げる場合は、ビューポートの幅ではなくパーセント単位を使用することをお勧めします。 2015812183029975.png (700×443)

全高を占める要素: vh > %


一方、要素をページの高さ全体に広げる場合は、パーセント単位よりも vh の方がはるかに優れています。

パーセンテージで定義された要素のサイズはその親要素によって決定されるため、親要素も画面の高さ全体を占める場合にのみ、画面の高さ全体を占める要素を持つことができます。これは通常、要素の親要素を HTML 要素にするために、修正する要素を配置するか、何らかのプログラムに依存する必要があることを意味します。

しかし、vh を使用すると、次のように書くだけで簡単になります。

.example {   
  height: 100vh;   
}

.example 要素がどれほどネストされているかに関係なく、ビューポートのサイズに応じてサイズを変更できます。最近のほとんどのページには通常、水平スクロール バーがないため、スクロール バーの問題も問題になりません。

ここでは、vh ユニットを使用していくつかのデザインを簡単に作成する方法の例をいくつか示します。

全画面背景画像


vh ユニットの一般的な使用法は、デバイスのサイズに関係なく、画面の高さと幅全体にわたる背景画像を作成することです。これは、vh:

.bg {   
  position: relative;   
  background: url('bg.jpg') center/cover;   
  width: 100%;   
  height: 100vh;   
}

2015812183125193.gif (400×256)
を使用すると簡単に実現できます。全画面を満たすコンテンツブロックは「マルチページ」のようなものです

同様に、「マルチページ」の効果も実現できます。ページを作成することによって 各コンテンツ ブロックはビューポートの高さと幅全体に広がります。

section {   
  width: 100%;   
  height: 100vh;   
}

2015812183151268.gif (400×252)JavaScriptを使用すると、ページをめくるような錯覚を実現できます。

$('nav').on('click', function() {   
  if ( $(this).hasClass('down') ) {   
    var movePos = $(window).scrollTop() + $(window).height();   
  }   
  if ( $(this).hasClass('up') ) {   
    var movePos = $(window).scrollTop() - $(window).height();   
  }   
  $('html, body').animate({   
    scrollTop: movePos   
  }, 1000);   
})

エリア内の画像

vh単位を使用して、ページ内の画像のサイズを制御することもできます。たとえば、記事では、画面サイズに関係なく、画像全体をページ上で表示できるようにしたい場合があります。

これを行うには、次のように解決できます:

img {   
      width: auto; /* 图片宽度根据高度按比例调整*/
      max-width: 100%; /* 图片不超过父元素的宽度 */
      max-height: 90vh; /* 图片不超过视口的高度 */
      margin: 2rem auto;    
    }

2015812183213972.gif (400×252)
ブラウザのサポート

これらのユニットは比較的新しいため、一部のブラウザで使用するとまだ問題がいくつかあります。これらの問題を解決する方法は次のとおりです—


2015812183232355.jpg (963×314) 以上がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。

関連する推奨事項:

CSS の重み、カスケード、重要性 (!重要) の分析


CSS3 を使用してテキストが右にループする点滅効果を実現する

CSS3 でカスタムの「W」字型のランニング軌道を実装する方法

以上がCSS でのウィンドウ単位とパーセント単位の使用についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。