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

Web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

開發(fā) 前端
前端開發(fā)人員在構(gòu)建網(wǎng)站時需要做的一個決定是引入圖片的方式。它可以是<img>標簽,或者是通過CSS background 屬性,還可以使用 SVG<image>。選擇正確的方式是很重要的,它對性能和可訪問性有很大的影響。

 前端開發(fā)人員在構(gòu)建網(wǎng)站時需要做的一個決定是引入圖片的方式。它可以是標簽,或者是通過CSS background 屬性,還可以使用 SVG。選擇正確的方式是很重要的,它對性能和可訪問性有很大的影響。

[[323455]]

在本文中,我們會學(xué)習(xí)引入圖像的各種方式,以及每種方式的優(yōu)點和缺點,以及何時使用和為什么使用它們。

HTML img 元素

最簡單的情況下,img元素必須包含src屬性:

  1. <img src="cool.jpg" alt=""

設(shè)置寬度和高度屬性

在頁面加載時,它們會在頁面圖像加載時發(fā)生一些布局變化。為了避免這種情況,我們可以為它設(shè)置width和height屬性:

  1. <img src="cool.jpg" width="200" height="100" alt=""

雖然對某些人來說,這可能看起來太過簡單了,但它是有用的。我們用圖例的方式來理清這個概念:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

我們看到到右側(cè)圖片即使尚未加載仍保留了空間?那是因為設(shè)置了寬度和高度。

通過 CSS 隱藏圖像

圖像可以用 CSS 隱藏。但是,它仍將加載在頁面中。因此,在執(zhí)行此操作時請小心。如果一個圖像應(yīng)該被隱藏,那么它可能是出于裝飾的目的。

 

  1. img { 
  2.     display: none; 

同樣,上面的方法也不能阻止瀏覽器加載圖像,即使它在視覺上是隱藏的。原因是被認為是一個被替換的元素,所以我們無法控制它所加載的內(nèi)容。

可訪問性問題

通過將alt屬性設(shè)置為有意義的描述,用來訪問 HTML 圖像,這對于屏幕閱讀器用戶非常有幫助。

然而,如果一個alt描述是不需要的,請不要刪除它,如果你這樣做,圖像src將被讀出,這對可訪問性非常不利。

不僅如此,如果圖像因為某種原因沒有加載,并且它有一個清晰的alt,它將作為一個回退顯示。同樣通過圖例來演示一下。

假設(shè)我們有以下圖片:

  1. <img class="food-thumb" width="300" height="200" src="cheescake.jpg"
  2.  
  3. <img class="food-thumb" width="300" height="200" src="cheescake.jpg" alt=""

當(dāng)src無效,圖片沒有加載時。第一個沒有alt屬性,而第二個是空的alt屬性,下面是它們的視覺效果:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

沒有alt的圖片仍然保留了它的空間,這很混亂,而且不利于訪問。而另一個alt為空的圖片,會折疊起來看起來像一個小點,這里因為它有邊框。

但是,當(dāng)alt屬性有值,它看起來是這樣的:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

這不是一個很好的反饋嗎?此外,當(dāng)圖像源失敗時,可以向它們添加偽元素。

響應(yīng)式圖像

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

的優(yōu)點在于可以針對特定視口大小將其擴展為具有多個版本的照片。我們有兩種不同的方式來生成一組響應(yīng)式圖像:

1.srcset屬性

  1. <img src="small.jpg" srcset="medium.jpg 500w, large.jpg 800w" alt=""

這很簡單。對我來說,srcset可以根據(jù)屏幕寬度顯示多個圖像尺寸,這并不是一種完美的解決方案。它讓瀏覽器選擇合適的圖像,而我們對此無能為力。

2.picture 標簽

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

另一種選擇是使用 元素。我更喜歡這種方式,因為它更容易預(yù)測。

事例源碼:https://codepen.io/shadeed/pen/d703aee137f38c138f2323a0252548ac?editors=1100

調(diào)整圖像大小

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

對于,我們還可以使用的一組很好的特性object-fit和object-position。它們可以控制的大小和定位,就像CSS背景圖像。

object-fit 值有:fill, contain, cover, none, scale-down。例如:

  1. img { 
  2.     object-fit: cover; 
  3.     object-position: 50% 50%; 

CSS背景圖片

使用CSS背景顯示圖像時,它需要一個具有內(nèi)容或特定寬度或高度的元素。通常,背景圖像的主要用途應(yīng)該是用于裝飾目的。

何使用 CSS 背景圖片

首先,我們需要一個元素

 

  1. // html 
  2. <div class="element">Some content</div> 
  3.  
  4. // css 
  5. .element { 
  6.     background: url('cool.jpg'); 

 

 

多個背景

使用CSS背景圖片的好處是可以設(shè)置多個背景??紤]以下示例:

 

  1. .element { 
  2.     background: url('cool-1.jpg'), url('cool-2.jpg'); 

隱藏圖像

我們可以在特定視口中隱藏和顯示圖像,如果未使用CSS設(shè)置圖片,則不會下載該圖片。與使用相比,這是一個額外的好處。

在上面的示例中,我們有一個背景圖像,僅在視口寬度大于700px時顯示。

可訪問性問題

如果使用不當(dāng),背景圖像可能會影響可訪問性。例如,將其用于文章主題,這對于文章至關(guān)重要。

非開發(fā)人員無法下載

普通人知道,如果要保存圖像,只需單擊鼠標左鍵,然后選擇保存即可。CSS 背景圖片并非如此,我們必須先檢查元素,然后在DevTools中的url中打開鏈接,然后才能下載隨CSS添加的圖像。

偽元素

可以將偽元素與CSS背景圖像一起使用,例如在圖像頂部顯示覆蓋圖。對于這是不可能的,直到我們?yōu)榀B加層添加單獨的元素。

SVG Image

SVG被認為是一種圖像,它比較大的功能是在不影響質(zhì)量的情況下進行縮放。此外,使用SVG,我們可以嵌入JPG、PNG或SVG圖像。參見下面的 HTML:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

你是否注意到了prepareAspectRatio?它的作用是可以讓圖像占據(jù)SVG的整個寬度和高度,而不會被拉伸或壓縮。

當(dāng)寬度較大時,它將填充其父級(SVG)寬度而不會拉伸。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

這非常類似于 CSS 中的object-fit: cover或background-size: cover。

可訪問性問題

關(guān)于SVG 的可訪問性,這使我想起了<title>元素。例如,我們可以像下面這樣添加它:

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

我們還可以使用元素

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

非開發(fā)人員無法下載

必須先檢查元素并復(fù)制圖像的URL,然后才能下載嵌入SVG的圖像。但是,如果我們要防止用戶下載特定的圖像,這可能是一件好事。

用例

Hero Section

在構(gòu)建hero section時,有時我們需要在標題和其他內(nèi)容下方的圖像。參見下圖:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

一些要求:

  • 背景圖片能夠動態(tài)替換
  • 圖片有一個覆蓋層,讓閱讀更容易
  • 圖像有三種尺寸:小號、中號和大號。每一個都是針對一個特定的視口。

在開始解決方案之前,讓我們先問問自己這種背景的性質(zhì)。這是一些入門問題:

  1. 為用戶保留這個圖像很重要嗎,還是可以跳過它?
  2. 我們是否需要在所有視口尺寸上使用它?
  3. 它是靜態(tài)的還是動態(tài)變化的?

解決方案1

通過使用多個CSS背景,我們可以將一個背景作為疊加層,將另一個背景作為實際圖像。請看下面的CSS:

 

  1. .hero { 
  2.     background-image: linear-gradient(rgba(0, 0, 0, 0.4),  
  3.                                       rgba(0, 0, 0, 0.4)), var('landscape.jpg'); 
  4.     background-repeat: no-repeat; 
  5.     background-size: 100%, cover; 

雖然此解決方案有效,但可以使用 JavaScript 動態(tài)更改背景圖片。見下面:

  1. <section class="hero"  
  2.    style="background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('landscape.jpg');"
  3.   <!-- Hero content --> 
  4. </section

 

 

這里添加了一個內(nèi)聯(lián)樣式。雖然這是可行的,但它看起來很丑,而且不實用。

也許我們可以使用CSS變量?讓我們來探索一下。

  1. <section class="hero" style="--bg-url: url('landscape.jpg')"
  2.   <!-- Hero content --> 
  3. </section

 

 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

現(xiàn)在,我們可以輕松地更新--bg-url變量來動態(tài)更改背, 這比內(nèi)聯(lián)的東西好一百萬倍。

小結(jié):

  1. 這種方案只有在圖片不重要才適用
  2. 這種方案只適合一些靜態(tài)網(wǎng)站,因為沒有從后臺拉取圖片

事例源碼:https://codepen.io/shadeed/pen/17978a2d824fd51a3b27c2c2d099a522

解決方案2

該方案是可以使用一個 img 標簽:

  1. <section class="hero"
  2.   <h2 class="hero__title">Using Images in CSS</h2> 
  3.   <p class="hero__desc">An article about which and when to use</p> 
  4.   <img src="landscape.jpg" alt=""
  5. </section

在CSS中,我們需要將圖片絕對定位在內(nèi)容下方,并且還需要使用偽元素作為疊加層。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

此解決方案的優(yōu)點在于,可以輕松更改圖片的src屬性。同樣,如果圖像很重要,它將會更加有用。

另外,我喜歡使用HTML 的功能是能夠在未加載圖片的情況下添加回退?;赝酥辽倏梢允箖?nèi)容保持可讀性。

 

  1. .hero img { 
  2.     /* Other styles */ 
  3.     background: #2962ff; 
  4.   } 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

在圖片源路徑不對時,背景顏色是一個代替方面。

事例源碼:https://codepen.io/shadeed/pen/73a2ca78141fcab39d6db9d5bd982728?editors=1100

網(wǎng)站 Logo

網(wǎng)站 Logo是很重要的,因為它可以將網(wǎng)站與其他網(wǎng)站區(qū)分開。要嵌入徽標,我們有一些選擇:

  • img -> png,jpg, orsvg
  • 內(nèi)聯(lián)SVG
  • 背景圖

接下來,我們來看看哪種方式更合適。

帶有很多細節(jié)的 Logo

當(dāng)徽標具有許多細節(jié)或形狀時,將其用作嵌入式SVG可能沒有好處。我建議使用,圖像類型可以是png,jpg或svg。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

需要動畫的簡單 Logo

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

我們有一個簡單的logo ,其中包含形狀和文字。懸停時,形狀和文本需要更改顏色。怎么做?對我來說比較好的解決方案是使用嵌入式SVG。

HTML

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

CSS

 

  1. .logo rect, 
  2. .logo text { 
  3.   transition: 0.3s ease-out
  4.  
  5. .logo:hover rect, 
  6. .logo:hover text { 
  7.   fill: #4a7def; 

事例源碼:https://codepen.io/shadeed/pen/4005077cc543647148007f4834c0585c?editors=0100

響應(yīng) Logo

這讓我想起了Smashing Magazine的logo。我喜歡它從一個小圖標變成一個完整的徽標。參見下面的模型:

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

優(yōu)秀的解決方案是使用 元素,可以在其中添 加logo 的兩個版本。如下所示:

  1. <a class="logo" href="/"
  2.     <picture> 
  3.       <source media="(min-width: 1350px)" srcset="sm-logo--full.svg"
  4.         <img src="sm-logo.svg" alt="Smashing Magazine"
  5.         </picture> 
  6.   </a> 

在CSS中,我們需要將視口的寬度更改為等于或大于1350px。

 

  1. .logo { 
  2.   display: inline-block; 
  3.   width: 45px; 
  4.  
  5. @media (min-width: 1350px) { 
  6.   .logo { 
  7.     width: 180px; 
  8.   } 

這是簡單而直接的解決方案。

事例源碼:https://codepen.io/shadeed/pen/6cf55d4e87b7c443820bd5f8694587a8?editors=1100

帶有漸變的Logo

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

當(dāng) logo 具有漸變時,從Illustrator或Sketch等設(shè)計應(yīng)用程序?qū)⑵鋵?dǎo)出的過程可能并不優(yōu)秀,有時會中斷。

使用SVG,我們可以輕松地為logo添加漸變。我添加了 并將其用作文本填充。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

事例源碼:https://codepen.io/shadeed/pen/9bf3bee3d08a40411effb5d65f25b5c1?editors=1100

用戶頭像

對于用戶頭像,它們具有很多形狀,但最常見的是矩形或圓形。在此用例中,會介紹一個對你有用的重要技巧。

首先,讓我們看下面的模型。請注意,我們有一個優(yōu)秀的化身,并且100%清晰。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

但是,當(dāng)用戶上傳半白色頭像或非常淺的頭像時,這個設(shè)計就不太好了。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

請注意,在上面的模型中,除非真正專注看,否則尚不清楚其中是否有一個圓圈。這是一個問題。為了解決這個問題,我們應(yīng)該在頭像內(nèi)添加邊框,以防圖像太亮看不清除。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

我們有幾個選擇

  • img元素
  • img 和 div 元素
  • div與CSS背景
  • SVG image

哪一個比較好?我們來探索探索。

使用 HTML `<img>`

你可能首先想到的是添加一個邊框,對吧?讓我們來探討一下這個問題。

 

  1. .avatar { 
  2.     border: 2px solid #f2f2f2; 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

我們的目標是使內(nèi)部邊框與圖像融合在一起,這種不太實用。

使用 `<img>` 和 `<div>` 元素

 

現(xiàn)在的問題是,要添加內(nèi)部邊框,我們不能使用box-shadow,因為它無法在圖像上使用。解決方案用

包裹 頭像中,并添加專用于內(nèi)部邊框的元素。

 

HTML

  1. <div class="avatar-wrapper"
  2.      <img class="avatar" src="shadeed2.jpg" alt="A photo of Ahmad Shadeed"
  3.      <div class="avatar-border"></div> 
  4. </div> 

 

 

CSS

 

  1. .avatar-wrapper { 
  2.   position: relative
  3.   width: 150px; 
  4.   height: 150px; 
  5.  
  6. .avatar-border { 
  7.   position: absolute
  8.   left: 0; 
  9.   top: 0; 
  10.   width: 100%; 
  11.   height: 100%; 
  12.   border-radius: 50%; 
  13.   border: 2px solid rgba(0, 0, 0, 0.1); 

通過在<div>上使用透明度10%黑色的邊框,我們可以確保邊框與深色圖像融合,并且只有在圖像較亮的情況下才可見。參見下面的模型:

 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

事例地址:https://codepen.io/shadeed/pen/da23d9a18dac14692a97e1bc6e86a5ff?editors=1100

使用`<div>`與CSS背景

 

如果我要使用<div>來顯示頭像,則可能表示該圖像具有裝飾性。我記得一個用例,它是分散在頁面中的隨機頭像。

 

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

HTML

  1. <div class="avatar" style="--img-url: url(shadeed2.jpg)"></div> 

 

 

 

CSS

 

  1. .avatar { 
  2.   background: var(--img-url) center/cover; 
  3.   width: 150px; 
  4.   height: 150px; 
  5.   border-radius: 50%; 
  6.   box-shadow: inset 0 0 0 2px rgba(#000, 0.1); 

事例地址:https://codepen.io/shadeed/pen/39eb9dac364ec15b9ab9bae7fe3a7148?editors=0100

使用 SVG ``

對我來說,這是最有趣的解決方案。我在檢查Facebook的新設(shè)計時注意到了它。

 

web 圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點

 

先對其進行剖析,它包含以下內(nèi)容:

  • 用于將圖像剪切為圓形(circle )的蒙版(mask )
  • 對其應(yīng)用了蒙版的組
  • image本身帶有preserveAspectRatio =“ xMidYMid”
  • 用于內(nèi)邊界的圓

 

  1. circle { 
  2.   stroke-width: 2; 
  3.   stroke: rgba(0, 0, 0, 0.1); 
  4.   fill: none; 

事例地址:https://codepen.io/shadeed/pen/b17d34b5c23cc90fdc4573779544c8c7?editors=0100

 

責(zé)任編輯:華軒 來源: 今日頭條
相關(guān)推薦

2010-02-24 12:41:58

WCF異常處理

2010-02-22 16:00:22

WCF序列化

2016-12-06 09:45:30

Web框架優(yōu)缺點

2021-01-28 17:26:57

LoRa網(wǎng)絡(luò)架構(gòu)網(wǎng)絡(luò)技術(shù)

2017-11-22 09:00:12

RAID類型磁盤

2021-04-12 14:40:50

人臉識別面部識別人工智能

2020-12-28 08:29:47

Vuecss框架

2020-05-13 09:01:23

Web隱藏技術(shù)元素

2009-10-23 13:03:15

2017-11-27 17:09:38

前端Web圖像優(yōu)化

2017-10-23 13:20:37

2023-10-08 08:46:29

Java遍歷方式

2017-03-06 14:45:27

超線程技術(shù)處理器技術(shù)服務(wù)器

2016-02-24 16:06:35

Ajax優(yōu)缺點

2010-08-23 10:50:39

DIV+CSS

2017-05-11 21:01:20

JavaScript創(chuàng)建對象面向?qū)ο缶幊?/a>

2019-10-31 11:16:57

Web框架Angular

2011-06-28 21:04:16

噴墨打印技術(shù)

2009-04-13 16:37:33

JSPWeb標簽

2023-12-04 09:15:00

Spring框架
點贊
收藏

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