自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

來學習一下CSS中的寬高比,讓 h5 開發(fā)更想你的夜!

開發(fā) 前端
在這篇文章中,我們將討論什么是寬高比,我們過去是怎么做的,新的做法是什么。當然,也會有一些用例,對它們進行適當?shù)幕赝恕?/div>

[[406458]]

在圖像和其他響應式元素的寬度和高度之間有一個一致的比例是很重要的。在CSS中,我們使用padding hack已經(jīng)很多年了,但現(xiàn)在我們在CSS中有了原生的長寬比支持。

在這篇文章中,我們將討論什么是寬高比,我們過去是怎么做的,新的做法是什么。當然,也會有一些用例,對它們進行適當?shù)幕赝恕?/p>

什么是高寬比

根據(jù)維基百科的說法:

在數(shù)學上,比率表示一個數(shù)字包含另一個數(shù)字的多少倍。例如,如果一碗水果中有八個橙子和六個檸檬,那么橙子和檸檬的比例是八比六(即8∶6,相當于比值4∶3)。

在網(wǎng)頁設計中,高寬比的概念是用來描述圖像的寬度和高度應按比例調(diào)整。

考慮下圖

 

比率是4:3,這表明蘋果和葡萄的比例是4:3。

換句話說,我們可以為寬高比為4:3的最小框是4px * 3px框。當此盒式高度按比例調(diào)整為其寬度時,我們將有一個致寬尺寸的框。

考慮下圖。

 

盒子被按比例調(diào)整大小,其寬度和高度之間的比例是一致的?,F(xiàn)在,讓我們想象一下,這個盒子里有一張重要的圖片,我們關(guān)心它的所有細節(jié)。

請注意,無論大小如何,圖像細節(jié)都被保留。通過擁有一致的高寬比,我們可以獲得以下好處

  • 整個網(wǎng)站的圖像將在不同的視口大小上保持一致。
  • 我們也可以有響應式的視頻元素。
  • 它有助于設計師創(chuàng)建一個圖像大小的清晰指南,這樣開發(fā)者就可以在開發(fā)過程中處理它們。

計算寬高比

為了測量寬高比,我們需要將寬度除以如下圖所示的高度。

寬度和高度之間的比例是1.33。這意味著這個比例應該得到遵守。請考慮

注意右邊的圖片,寬度÷高度的值是 1.02,這不是原來的長寬比(1.33或4:3)。

你可能在想,如何得出4:3這個數(shù)值?嗯,這被稱為最接近的正常長寬比,有一些工具可以幫助我們找到它。在進行UI設計時,強烈建議你確切地知道你所使用的圖像的寬高比是多少。使用這個網(wǎng)址可以幫我們快速計算。

網(wǎng)址地址:http://lawlesscreation.github.io/nearest-aspect-ratio/

在 CSS 中實現(xiàn)寬高比

我們過去是通過在CSS中使用百分比padding 來實現(xiàn)寬高比的。好消息是,最近,我們在所有主要的瀏覽器中都得到了aspect-ratio的原生支持。在深入了解原生方式之前,我們先首先解釋一下好的老方法。

當一個元素有一個垂直百分比的padding時,它將基于它的父級寬度。請看下圖。 

當標題有padding-top: 50%時,該值是根據(jù)其父元素的寬度來計算的。因為父元素的寬度是200px,所以padding-top會變成100px。

為了找出要使用的百分比值,我們需要將圖像的高度除以寬度。得到的數(shù)字就是我們要使用的百分比。

假設圖像寬度為260px,高度為195px。

  1. Percentage padding = height / width 

195/260的結(jié)果為 0.75(或75%)。

我們假設有一個卡片的網(wǎng)格,每張卡片都有一個縮略圖。這些縮略圖的寬度和高度應該是相等的。

由于某些原因,運營上傳了一張與其他圖片大小不一致的圖片。注意到中間那張卡的高度與其他卡的高度不一樣。

你可能會想,這還不容易解決?我們可以給圖片加個object-fit: cover。問題解決了,對嗎?不是這么簡單滴。這個解決方案在多種視口尺寸下都不會好看。

注意到在中等尺寸下,固定高度的圖片從左邊和右邊被裁剪得太厲害,而在手機上,它們又太寬。所有這些都是由于使用了固定高度的原因。我們可以通過不同的媒體查詢手動調(diào)整高度,但這不是一個實用的解決方案。

我們需要的是,無論視口大小如何,縮略圖的尺寸都要一致。為了實現(xiàn)這一點,我們需要使用百分比padding來實現(xiàn)一個寬高比。

HTML

  1. <article class="card"
  2.   <div class="card__thumb"
  3.     <img src="thumb.jpg" alt="" /> 
  4.   </div> 
  5.   <div class="card__content"
  6.     <h3>Muffins Recipe</h3> 
  7.     <p>Servings: 3</p> 
  8.   </div> 
  9. </article> 

CSS

  1. .card__thumb { 
  2.   position: relative
  3.   padding-top: 75%; 
  4.  
  5. .card__thumb img { 
  6.   position: absolute
  7.   left: 0; 
  8.   top: 0; 
  9.   width: 100%; 
  10.   height: 100%; 
  11.   object-fit: cover; 

通過上述,我們定義了卡片縮略圖包裝器(.card__thumb)的高度取決于其寬度。另外,圖片是絕對定位的,它有它的父元素的全部寬度和高度,有object-fit: cover,用于上傳不同大小的圖片的情況。請看下面的動圖。

圖片

請注意,卡片大小的變化和縮略圖的長寬比沒有受到影響。

aspect-ratio 屬性

今年早些時候,Chrome、Safari TP和Firefox Nightly都支持aspect-ratioCSS 屬性。最近,它在Safari 15的官方版本中得到支持。

我們回到前面的例子,我們可以這樣改寫它。

  1. /* 上面的方式 */ 
  2. .card__thumb { 
  3.   position: relative
  4.   padding-top: 75%; 
  5.  
  6. /* 使用 aspect-ratio 屬性 */ 
  7. .card__thumb { 
  8.   position: relative
  9.   aspect-ratio: 4/3; 

請看下面的動圖,了解寬高比是如何變化的。

Demo 地址:https://codepen.io/shadeed/pen/ZEeMjZe

有了這個,讓我們探索原始縱橫比可以有用的一些用例,以及如何以逐步增強的方法使用它。

漸進增強

我們可以通過使用CSS @supports和CSS變量來使用CSS aspect-ratio。

  1. .card { 
  2.   --aspect-ratio: 16/9; 
  3.   padding-top: calc((1 / (var(--aspect-ratio))) * 100%); 
  4.  
  5. @supports (aspect-ratio: 1) { 
  6.   .card { 
  7.     aspect-ratio: var(--aspect-ratio); 
  8.     padding-top: initial; 
  9.   } 

Logo Images

來看看下面的 logo

 

你是否注意到它們的尺寸是一致的,而且它們是對齊的?來看看幕后的情況。

  1. // html 
  2. <li class="brands__item"
  3.   <a href="#"
  4.     <img src="assets/batch-2/aanaab.png" alt="" /> 
  5.   </a> 
  6. </li> 
  1. .brands__item a { 
  2.   padding: 1rem; 
  3.  
  4. .brands__item img { 
  5.   width: 130px; 
  6.   object-fit: contain; 
  7.   aspect-ratio: 2/1; 

我添加了一個130px的基本寬度,以便有一個最小的尺寸,而aspect-ratio會照顧到高度。


藍色區(qū)域是圖像的大小,object-fit: contain是重要的,避免扭曲圖像。

Responsive Circles

你是否曾經(jīng)需要創(chuàng)建一個應該是響應式的圓形元素?CSS aspect-ratio是這種使用情況的最佳選擇。

  1. .person { 
  2.   width: 180px; 
  3.   aspect-ratio: 1; 

如果寬高比的兩個值相同,我們可以寫成aspect-ratio: 1而不是aspect-ratio: 1/1。如果你使用flexbox或grid,寬度將是可選的,它可以被添加作為一個最小值。

~完,我是小智,寶,你學會了嗎~

作者:Ahmad Shadeed 譯者:前端小智 來源:shadeed

原文:https://ishadeed.com/article/css-aspect-ratio/

 

責任編輯:姜華 來源: 大遷世界
相關(guān)推薦

2022-09-27 07:30:16

H5益智游戲引擎

2015-11-10 11:38:06

2020-12-03 18:07:07

H5主題用戶

2020-10-15 11:18:13

Linux內(nèi)核虛擬機

2022-03-28 07:52:31

H5小游戲開發(fā)教程頁面基礎布局

2023-02-04 20:08:24

前端開發(fā)

2020-06-10 07:38:30

Spring框架周期

2023-05-03 09:09:28

Golang數(shù)組

2023-12-11 13:09:00

CSSlinear緩沖函數(shù)

2021-09-27 08:49:03

開發(fā) CSS padding

2016-10-25 17:52:56

H5APP教材

2021-05-31 06:00:55

Python 3.4枚舉開發(fā)

2023-09-06 08:57:33

NLTK自然語言處理工具

2020-07-29 10:20:28

Redis數(shù)據(jù)庫字符串

2020-12-13 12:14:45

H5開發(fā)H5-Dooring

2012-07-22 15:49:25

Java

2021-08-30 07:49:34

數(shù)據(jù)庫數(shù)倉Doris

2015-09-21 09:38:14

營銷H5

2015-08-14 10:42:05

2023-04-23 09:01:43

CSS動畫合成
點贊
收藏

51CTO技術(shù)棧公眾號