我要成為切版魔法師 #2 - 讓圖片乖乖聽話的 3 種方法

更新於 發佈於 閱讀時間約 3 分鐘

圖片可以說是 HTML 元素中以不受控出名的元素了,在預設情況下,完全不受父容器影響,以下就來看看有哪些方法讓圖片依照你的想法變化吧。

依據不同目的,設定 img 圖片標籤

一、圖片會填滿父容器,但有機會導致父容器有留白

在 img 標籤設定 max-width: 100%,這個語法的意思是:

  1. 它會填滿父容器,同時不會超出自己的圖片尺寸、導致模糊
  2. 如上面特點,不會超出圖片本身像素,即代表有機會導致圖片沒有填滿父容器、出現留白。發生這種事情時,通常代表的是圖片輸出不夠大張,像素不夠。

有時候​需要強制讓圖片撐滿整個空間,這時候就可以使用第二個方法。

二、讓圖片強制填滿父層、且不變形

在 img 標籤設定 width: 100%object-fit: cover

  • width: 100%:讓圖片完全填滿父容器。
  • object-fit: cover:圖片會填滿父容器,但不會變形。
  • 有時候會搭配 object-position 語法調整圖片位置(要顯示圖片的哪個部分)。

需要注意的是,如果圖片有設定 max-width: 100%,那麼 object-fit: cover 就不會有作用囉,因為前者的語法已經將圖片設定成不會超出本身的尺寸了。

三、在 HTML 文件中將 img 設定基本寬高

透過 img 標籤的屬性 width 和 height 設定圖片寬高,因為並不是設定在 style 裡面,所以不會有 CSS 權重的問題

<img width="40px"​ height="40px" alt="logo">

但這個方法有幾個需要注意的地方:

  1. 製作 RWD 較為不便,還是需要進到 CSS 裡面設定,較適合使用在網頁中的小圖示上
  2. 經常會導致圖片變形,需要搭配 object-fit: cover 語法

我自己的經驗是,圖片大多會先採用第一種寫法,若有特殊需求就會再額外設定第二種寫法,然後在小圖示上斟酌使用第三種寫法。

額外討論1:background-image 與 img 的使用情況

通常會將網頁中有意義的圖片使用 img 標籤表示,因為這時才有語意化的含義,而裝飾元素就會使用 CSS 語法 background-image 放入網頁中。

background-image 相關屬性有:

  • background-image:引入圖片路徑
  • background-position:指定圖片位置(想顯示圖片哪個部分)
  • background-size:指定圖片尺寸
  • background-repeat:預設值為 repeat,若要圖片不再重複出現要設定 no-repeat

若使用這個方法,因為這個放置圖片的方式是依附在元素上,本身無法撐出寬高,需要在元素額外設定寬高,圖片才會正常顯示。

background-image 的好處是製作 RWD 很方便,有時候圖片變化較大,需要額外替換圖檔,這時候直接使用 media query 和改變 background-image 圖片路徑即可,只是這樣就沒有像 img 標籤有語意化的效果了。

額外討論2:如果要使用 img 標籤達到 RWD 效果呢?

可以搭配 picturesource 標籤,這部分還蠻多設定的,之後會再寫一篇文章介紹。

希望看完這篇文章,大家都能隨心所欲控制網頁中的圖片囉!


留言
avatar-img
留言分享你的想法!
avatar-img
傑米的沙龍
7會員
30內容數
正在一點一滴學習程式,相信知識量總有一天會匯聚成大海,目前專門研究前端中。
你可能也想看
Thumbnail
每年4月、5月都是最多稅要繳的月份,當然大部份的人都是有機會繳到「綜合所得稅」,只是相當相當多人還不知道,原來繳給政府的稅!可以透過一些有活動的銀行信用卡或電子支付來繳,從繳費中賺一點點小確幸!就是賺個1%~2%大家也是很開心的,因為你們把沒回饋變成有回饋,就是用卡的最高境界 所得稅線上申報
Thumbnail
每年4月、5月都是最多稅要繳的月份,當然大部份的人都是有機會繳到「綜合所得稅」,只是相當相當多人還不知道,原來繳給政府的稅!可以透過一些有活動的銀行信用卡或電子支付來繳,從繳費中賺一點點小確幸!就是賺個1%~2%大家也是很開心的,因為你們把沒回饋變成有回饋,就是用卡的最高境界 所得稅線上申報
Thumbnail
當今的數位設計世界裡,清晰地呈現視覺元素是至關重要的。無論是在創建網站、設計海報,還是製作社交媒體內容,精準地移除圖像背景或不必要的像素,可以顯著提升作品的視覺效果和專業度。本文將介紹幾種在Adobe Photoshop中去除背景的高效方法,以及如何在Adobe Illustrator和InDesi
Thumbnail
當今的數位設計世界裡,清晰地呈現視覺元素是至關重要的。無論是在創建網站、設計海報,還是製作社交媒體內容,精準地移除圖像背景或不必要的像素,可以顯著提升作品的視覺效果和專業度。本文將介紹幾種在Adobe Photoshop中去除背景的高效方法,以及如何在Adobe Illustrator和InDesi
Thumbnail
前篇測試如何把提示詞生成的圖像細節提高,這篇要測試的工作流是把任意圖像載入後經由放大模型放大,同時測試放大後重繪看看效果如何。
Thumbnail
前篇測試如何把提示詞生成的圖像細節提高,這篇要測試的工作流是把任意圖像載入後經由放大模型放大,同時測試放大後重繪看看效果如何。
Thumbnail
本文介紹四種簡單有效的設計方法,包括使用幾何圖形填滿空白、重複使用文字填充版面、用十字線引導視覺、用對角線創造動感。這些方法可以有效解決版面太空的問題。舉例證明瞭這些方法在海報設計和網站設計中的應用。最後作者鼓勵讀者去摸索嘗試,提供自己的設計風格,並同時推薦了使用社群繪畫經營工具的人參考。
Thumbnail
本文介紹四種簡單有效的設計方法,包括使用幾何圖形填滿空白、重複使用文字填充版面、用十字線引導視覺、用對角線創造動感。這些方法可以有效解決版面太空的問題。舉例證明瞭這些方法在海報設計和網站設計中的應用。最後作者鼓勵讀者去摸索嘗試,提供自己的設計風格,並同時推薦了使用社群繪畫經營工具的人參考。
Thumbnail
有些人會將排版定義為各種視覺元素,例如是文字、形狀、圖片,各自在平面空間上的相對位置,帶來的視覺和閱讀效果。在平面上的X和Y座標以外,我們可考慮一下Z座標,視覺元素之間的重疊,能帶來甚麼互補。要是你看膩了左圖右字的穩定型排版,或是漸變遮罩的圖文配合,透過個案分析與練習,為知識庫增加多一種版型吧。
Thumbnail
有些人會將排版定義為各種視覺元素,例如是文字、形狀、圖片,各自在平面空間上的相對位置,帶來的視覺和閱讀效果。在平面上的X和Y座標以外,我們可考慮一下Z座標,視覺元素之間的重疊,能帶來甚麼互補。要是你看膩了左圖右字的穩定型排版,或是漸變遮罩的圖文配合,透過個案分析與練習,為知識庫增加多一種版型吧。
Thumbnail
切版有許多眉角需要注意,來探討那些經常導致切版結果與設計稿產生落差的原因。 一、文字的高度本體是 line-height:🔍 文字所佔據的高度不是由font-size決定,而是line-hight。一開始練習切版時,都想著設定好字的尺寸和字重就 ok 了吧?殊不知這是造成切出來的網頁與設計
Thumbnail
切版有許多眉角需要注意,來探討那些經常導致切版結果與設計稿產生落差的原因。 一、文字的高度本體是 line-height:🔍 文字所佔據的高度不是由font-size決定,而是line-hight。一開始練習切版時,都想著設定好字的尺寸和字重就 ok 了吧?殊不知這是造成切出來的網頁與設計
Thumbnail
圖片可以說是 HTML 元素中以不受控出名的元素了,在預設情況下,完全不受父容器影響,以下就來看看有哪些方法讓圖片依照你的想法變化吧。
Thumbnail
圖片可以說是 HTML 元素中以不受控出名的元素了,在預設情況下,完全不受父容器影響,以下就來看看有哪些方法讓圖片依照你的想法變化吧。
Thumbnail
你看的出來這張圖片的上下紋路有何不同嗎?這是我把兩張同樣的圖片接在一起,你可以放大來看紋路都是一樣的,差別只在於其中一個步驟採用別的方式,但是在結果上卻產生肉眼可見的差異,這一篇會先解釋我在圖像運算上的理解,後半段則說明如何運用在寫作上。
Thumbnail
你看的出來這張圖片的上下紋路有何不同嗎?這是我把兩張同樣的圖片接在一起,你可以放大來看紋路都是一樣的,差別只在於其中一個步驟採用別的方式,但是在結果上卻產生肉眼可見的差異,這一篇會先解釋我在圖像運算上的理解,後半段則說明如何運用在寫作上。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News