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

10年積累的成都網(wǎng)站建設(shè)、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有樺川免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
在本文中,我們會(huì)學(xué)習(xí)引入圖像的各種方式,以及每種方式的優(yōu)點(diǎn)和缺點(diǎn),以及何時(shí)使用和為什么使用它們。
HTML img 元素
最簡(jiǎn)單的情況下,img元素必須包含src屬性:
設(shè)置寬度和高度屬性
在頁(yè)面加載時(shí),它們會(huì)在頁(yè)面圖像加載時(shí)發(fā)生一些布局變化。為了避免這種情況,我們可以為它設(shè)置width和height屬性:
雖然對(duì)某些人來說,這可能看起來太過簡(jiǎn)單了,但它是有用的。我們用圖例的方式來理清這個(gè)概念:
我們看到到右側(cè)圖片即使尚未加載仍保留了空間?那是因?yàn)樵O(shè)置了寬度和高度。
通過 CSS 隱藏圖像
圖像可以用 CSS 隱藏。但是,它仍將加載在頁(yè)面中。因此,在執(zhí)行此操作時(shí)請(qǐng)小心。如果一個(gè)圖像應(yīng)該被隱藏,那么它可能是出于裝飾的目的。
- img {
- display: none;
- }
同樣,上面的方法也不能阻止瀏覽器加載圖像,即使它在視覺上是隱藏的。原因是被認(rèn)為是一個(gè)被替換的元素,所以我們無法控制它所加載的內(nèi)容。
可訪問性問題
通過將alt屬性設(shè)置為有意義的描述,用來訪問 HTML 圖像,這對(duì)于屏幕閱讀器用戶非常有幫助。
然而,如果一個(gè)alt描述是不需要的,請(qǐng)不要?jiǎng)h除它,如果你這樣做,圖像src將被讀出,這對(duì)可訪問性非常不利。
不僅如此,如果圖像因?yàn)槟撤N原因沒有加載,并且它有一個(gè)清晰的alt,它將作為一個(gè)回退顯示。同樣通過圖例來演示一下。
假設(shè)我們有以下圖片:
當(dāng)src無效,圖片沒有加載時(shí)。第一個(gè)沒有alt屬性,而第二個(gè)是空的alt屬性,下面是它們的視覺效果:
沒有alt的圖片仍然保留了它的空間,這很混亂,而且不利于訪問。而另一個(gè)alt為空的圖片,會(huì)折疊起來看起來像一個(gè)小點(diǎn),這里因?yàn)樗羞吙颉?/p>
但是,當(dāng)alt屬性有值,它看起來是這樣的:
這不是一個(gè)很好的反饋嗎?此外,當(dāng)圖像源失敗時(shí),可以向它們添加偽元素。
響應(yīng)式圖像
的優(yōu)點(diǎn)在于可以針對(duì)特定視口大小將其擴(kuò)展為具有多個(gè)版本的照片。我們有兩種不同的方式來生成一組響應(yīng)式圖像:
1.srcset屬性
這很簡(jiǎn)單。對(duì)我來說,srcset可以根據(jù)屏幕寬度顯示多個(gè)圖像尺寸,這并不是一種完美的解決方案。它讓瀏覽器選擇合適的圖像,而我們對(duì)此無能為力。
2.picture 標(biāo)簽
另一種選擇是使用 元素。我更喜歡這種方式,因?yàn)樗菀最A(yù)測(cè)。
事例源碼:https://codepen.io/shadeed/pen/d703aee137f38c138f2323a0252548ac?editors=1100
調(diào)整圖像大小
對(duì)于,我們還可以使用的一組很好的特性object-fit和object-position。它們可以控制的大小和定位,就像CSS背景圖像。
object-fit 值有:fill, contain, cover, none, scale-down。例如:
- img {
- object-fit: cover;
- object-position: 50% 50%;
- }
CSS背景圖片
使用CSS背景顯示圖像時(shí),它需要一個(gè)具有內(nèi)容或特定寬度或高度的元素。通常,背景圖像的主要用途應(yīng)該是用于裝飾目的。
何使用 CSS 背景圖片
首先,我們需要一個(gè)元素
- // html
Some content- // css
- .element {
- background: url('cool.jpg');
- }
多個(gè)背景
使用CSS背景圖片的好處是可以設(shè)置多個(gè)背景。考慮以下示例:
- .element {
- background: url('cool-1.jpg'), url('cool-2.jpg');
- }
隱藏圖像
我們可以在特定視口中隱藏和顯示圖像,如果未使用CSS設(shè)置圖片,則不會(huì)下載該圖片。與使用相比,這是一個(gè)額外的好處。
在上面的示例中,我們有一個(gè)背景圖像,僅在視口寬度大于700px時(shí)顯示。
可訪問性問題
如果使用不當(dāng),背景圖像可能會(huì)影響可訪問性。例如,將其用于文章主題,這對(duì)于文章至關(guān)重要。
非開發(fā)人員無法下載
普通人知道,如果要保存圖像,只需單擊鼠標(biāo)左鍵,然后選擇保存即可。CSS 背景圖片并非如此,我們必須先檢查元素,然后在DevTools中的url中打開鏈接,然后才能下載隨CSS添加的圖像。
偽元素
可以將偽元素與CSS背景圖像一起使用,例如在圖像頂部顯示覆蓋圖。對(duì)于這是不可能的,直到我們?yōu)榀B加層添加單獨(dú)的元素。
SVG Image
SVG被認(rèn)為是一種圖像,它比較大的功能是在不影響質(zhì)量的情況下進(jìn)行縮放。此外,使用SVG,我們可以嵌入JPG、PNG或SVG圖像。參見下面的 HTML:
你是否注意到了prepareAspectRatio?它的作用是可以讓圖像占據(jù)SVG的整個(gè)寬度和高度,而不會(huì)被拉伸或壓縮。
當(dāng)寬度較大時(shí),它將填充其父級(jí)(SVG)寬度而不會(huì)拉伸。
這非常類似于 CSS 中的object-fit: cover或background-size: cover。
可訪問性問題
關(guān)于SVG 的可訪問性,這使我想起了
我們還可以使用 元素
非開發(fā)人員無法下載
必須先檢查元素并復(fù)制圖像的URL,然后才能下載嵌入SVG的圖像。但是,如果我們要防止用戶下載特定的圖像,這可能是一件好事。
用例
Hero Section
在構(gòu)建hero section時(shí),有時(shí)我們需要在標(biāo)題和其他內(nèi)容下方的圖像。參見下圖:
一些要求:
- 背景圖片能夠動(dòng)態(tài)替換
- 圖片有一個(gè)覆蓋層,讓閱讀更容易
- 圖像有三種尺寸:小號(hào)、中號(hào)和大號(hào)。每一個(gè)都是針對(duì)一個(gè)特定的視口。
在開始解決方案之前,讓我們先問問自己這種背景的性質(zhì)。這是一些入門問題:
- 為用戶保留這個(gè)圖像很重要嗎,還是可以跳過它?
- 我們是否需要在所有視口尺寸上使用它?
- 它是靜態(tài)的還是動(dòng)態(tài)變化的?
解決方案1
通過使用多個(gè)CSS背景,我們可以將一個(gè)背景作為疊加層,將另一個(gè)背景作為實(shí)際圖像。請(qǐng)看下面的CSS:
- .hero {
- background-image: linear-gradient(rgba(0, 0, 0, 0.4),
- rgba(0, 0, 0, 0.4)), var('landscape.jpg');
- background-repeat: no-repeat;
- background-size: 100%, cover;
- }
雖然此解決方案有效,但可以使用 JavaScript 動(dòng)態(tài)更改背景圖片。見下面:
- style="background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('landscape.jpg');">
這里添加了一個(gè)內(nèi)聯(lián)樣式。雖然這是可行的,但它看起來很丑,而且不實(shí)用。
也許我們可以使用CSS變量?讓我們來探索一下。
現(xiàn)在,我們可以輕松地更新--bg-url變量來動(dòng)態(tài)更改背, 這比內(nèi)聯(lián)的東西好一百萬倍。
小結(jié):
- 這種方案只有在圖片不重要才適用
- 這種方案只適合一些靜態(tài)網(wǎng)站,因?yàn)闆]有從后臺(tái)拉取圖片
事例源碼:https://codepen.io/shadeed/pen/17978a2d824fd51a3b27c2c2d099a522
解決方案2
該方案是可以使用一個(gè) img 標(biāo)簽:
Using Images in CSS
An article about which and when to use
![]()
在CSS中,我們需要將圖片絕對(duì)定位在內(nèi)容下方,并且還需要使用偽元素作為疊加層。
此解決方案的優(yōu)點(diǎn)在于,可以輕松更改圖片的src屬性。同樣,如果圖像很重要,它將會(huì)更加有用。
另外,我喜歡使用HTML 的功能是能夠在未加載圖片的情況下添加回退?;赝酥辽倏梢允箖?nèi)容保持可讀性。
- .hero img {
- /* Other styles */
- background: #2962ff;
- }
在圖片源路徑不對(duì)時(shí),背景顏色是一個(gè)代替方面。
事例源碼:https://codepen.io/shadeed/pen/73a2ca78141fcab39d6db9d5bd982728?editors=1100
網(wǎng)站 Logo
網(wǎng)站 Logo是很重要的,因?yàn)樗梢詫⒕W(wǎng)站與其他網(wǎng)站區(qū)分開。要嵌入徽標(biāo),我們有一些選擇:
- img -> png,jpg, orsvg
- 內(nèi)聯(lián)SVG
- 背景圖
接下來,我們來看看哪種方式更合適。
帶有很多細(xì)節(jié)的 Logo
當(dāng)徽標(biāo)具有許多細(xì)節(jié)或形狀時(shí),將其用作嵌入式SVG可能沒有好處。我建議使用,圖像類型可以是png,jpg或svg。
需要?jiǎng)赢嫷暮?jiǎn)單 Logo
我們有一個(gè)簡(jiǎn)單的logo ,其中包含形狀和文字。懸停時(shí),形狀和文本需要更改顏色。怎么做?對(duì)我來說比較好的解決方案是使用嵌入式SVG。
HTML
CSS
- .logo rect,
- .logo text {
- transition: 0.3s ease-out;
- }
- .logo:hover rect,
- .logo:hover text {
- fill: #4a7def;
- }
事例源碼:https://codepen.io/shadeed/pen/4005077cc543647148007f4834c0585c?editors=0100
響應(yīng) Logo
這讓我想起了Smashing Magazine的logo。我喜歡它從一個(gè)小圖標(biāo)變成一個(gè)完整的徽標(biāo)。參見下面的模型:
優(yōu)秀的解決方案是使用 元素,可以在其中添 加logo 的兩個(gè)版本。如下所示:
在CSS中,我們需要將視口的寬度更改為等于或大于1350px。
- .logo {
- display: inline-block;
- width: 45px;
- }
- @media (min-width: 1350px) {
- .logo {
- width: 180px;
- }
- }
這是簡(jiǎn)單而直接的解決方案。
事例源碼:https://codepen.io/shadeed/pen/6cf55d4e87b7c443820bd5f8694587a8?editors=1100
帶有漸變的Logo
當(dāng) logo 具有漸變時(shí),從Illustrator或Sketch等設(shè)計(jì)應(yīng)用程序?qū)⑵鋵?dǎo)出的過程可能并不優(yōu)秀,有時(shí)會(huì)中斷。
使用SVG,我們可以輕松地為logo添加漸變。我添加了 并將其用作文本填充。
事例源碼:https://codepen.io/shadeed/pen/9bf3bee3d08a40411effb5d65f25b5c1?editors=1100
用戶頭像
對(duì)于用戶頭像,它們具有很多形狀,但最常見的是矩形或圓形。在此用例中,會(huì)介紹一個(gè)對(duì)你有用的重要技巧。
首先,讓我們看下面的模型。請(qǐng)注意,我們有一個(gè)優(yōu)秀的化身,并且100%清晰。
但是,當(dāng)用戶上傳半白色頭像或非常淺的頭像時(shí),這個(gè)設(shè)計(jì)就不太好了。
請(qǐng)注意,在上面的模型中,除非真正專注看,否則尚不清楚其中是否有一個(gè)圓圈。這是一個(gè)問題。為了解決這個(gè)問題,我們應(yīng)該在頭像內(nèi)添加邊框,以防圖像太亮看不清除。
我們有幾個(gè)選擇
- img元素
- img 和 div 元素
- div與CSS背景
- SVG image
哪一個(gè)比較好?我們來探索探索。
使用 HTML ``
你可能首先想到的是添加一個(gè)邊框,對(duì)吧?讓我們來探討一下這個(gè)問題。
- .avatar {
- border: 2px solid #f2f2f2;
- }
我們的目標(biāo)是使內(nèi)部邊框與圖像融合在一起,這種不太實(shí)用。
使用 ` 現(xiàn)在的問題是,要添加內(nèi)部邊框,我們不能使用box-shadow,因?yàn)樗鼰o法在圖像上使用。解決方案用 包裹 頭像中,并添加專用于內(nèi)部邊框的元素。 HTML CSS 通過在 事例地址:https://codepen.io/shadeed/pen/da23d9a18dac14692a97e1bc6e86a5ff?editors=1100 使用` 如果我要使用 HTML CSS 事例地址:https://codepen.io/shadeed/pen/39eb9dac364ec15b9ab9bae7fe3a7148?editors=0100 使用 SVG `` 對(duì)我來說,這是最有趣的解決方案。我在檢查Facebook的新設(shè)計(jì)時(shí)注意到了它。 先對(duì)其進(jìn)行剖析,它包含以下內(nèi)容: 事例地址:https://codepen.io/shadeed/pen/b17d34b5c23cc90fdc4573779544c8c7?editors=0100` 和 `
當(dāng)前文章:Web圖像技術(shù):前端引入圖片的各種方式及其優(yōu)缺點(diǎn)
標(biāo)題鏈接:http://m.5511xx.com/article/dpichgg.html


咨詢
建站咨詢
