圖片佈局css

来源:http://www.cnblogs.com/suyuanli/archive/2017/12/10/8016771.html
-Advertisement-
Play Games

對於平時項目開發中,經常要展示圖片。什麼水平居中顯示,垂直居中顯示,水平或垂直居中顯示...我們的髮際線就是這樣往後退的。 接下來要講的就是對於各種圖片佈局的css實現(這裡針對的是img標簽的不會使用到background) 1.最簡單的水平居中 .exa1{ width: 500px; heig ...


  • 對於平時項目開發中,經常要展示圖片。什麼水平居中顯示,垂直居中顯示,水平或垂直居中顯示...我們的髮際線就是這樣往後退的。
  • 接下來要講的就是對於各種圖片佈局的css實現(這裡針對的是img標簽的不會使用到background)

1.最簡單的水平居中

  <style>
    .exa1{
      width: 500px;
      height: 300px;
      margin: 0 auto;
      border: 1px solid #f00;
    }
    .exa1 img {
      display: block;
      width: 300px;
      margin: 0 auto;
    }
  </style>
</head>
<body>
  <h5>1.水平居中</h5>
  <div class="exa1">
    <img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1513482866&di=b7de9d07063752ad42c09826014e5a8d&imgtype=jpg&er=1&src=http%3A%2F%2Fpic1.5442.com%2F2015%2F0305%2F07%2F001.jpg" alt="">
  </div>
</body>
</html>

效果如下:
水平居中

2.垂直居中(這裡介紹兩種)

第一種:

在圖片父元素添加一個偽類before,利用vertical-align: middle的特性讓圖片垂直居中,不過感覺不是很方便

<style>
    .exa2{
        width: 500px;
        height: 300px;
        margin: 0 auto;
        border: 1px solid #f00;
    }
    .exa2::before{
        content: "";
        display: inline-block;
        height: 300px;
        vertical-align: middle;
    }
    .exa2 img {
        width: 300px;
        vertical-align: middle;
    }
</style>

<div class="exa2">
    <img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1513482866&di=b7de9d07063752ad42c09826014e5a8d&imgtype=jpg&er=1&src=http%3A%2F%2Fpic1.5442.com%2F2015%2F0305%2F07%2F001.jpg" alt="">
  </div>
第二種:

我比較推薦第二種使用css3的新屬性,不要跟我說相容,我不管。。。。
這裡主要用到transform的translateY它可以讓元素基於它本身移動,而且參數能填寫自身的百分百,看代碼好了

<style>
    .exa2{
        width: 500px;
        height: 300px;
        margin: 0 auto;
        border: 1px solid #f00;
    }
    .exa2 img {
        position: relative;         // 這裡通過定位,也可以選擇用absolute,看自己需要移動相對容器50%,在向上移動自身的50%,就達到垂直居中的效果了
        top: 50%;
        transform: translateY(-50%);
    }
</style>

<div class="exa2">
    <img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1513482866&di=b7de9d07063752ad42c09826014e5a8d&imgtype=jpg&er=1&src=http%3A%2F%2Fpic1.5442.com%2F2015%2F0305%2F07%2F001.jpg" alt="">
  </div>

效果如下:
垂直居中

垂直水平居中

這個我想通過上面說的應該也能猜到怎麼實現了

.exa2 img {
      width: 300px;
      position: relative;
      top: 50%;
      left: 50%;
      transform: translate(-50%,-50%);
    }
    

就是加個left和translateX,其它都一樣,如果要用垂直居中的第一種方法在父元素增加text-alegn:center;效果是一樣的。代碼就不貼了。
效果如下:
垂直水平居中


  • ps: 上面說到都是圖片在位置上的轉換,其實還有一種更簡單的方法,就是object-position屬性,用這個輕鬆簡單快捷搞定所有你要的佈局,可是它有一個之名缺點就是,IE下全方位不支持。如果不用相容IE的建議直接懟這個。

用法:
object-position:value, value;
value可以是'center', 'left', 'bottom', 'right'或者是百分百,px;


圖片自適應寬度或高度100%

可能項目中會有這種情況,容器大小是固定的,可是圖片的尺寸確不同的。
這裡就可以用到object-fit了在通過垂直水平居中就可以達到很好的效果了(同樣這裡也是不相容大IE的)。下麵是object-fit的值:

  • fill
    被替換的內容的大小,以填補該元素的內容框:對象的具體對象的大小是元素的使用寬度和高度。
  • contain
    被替換的內容的大小,為自身寬高比不變,適應該元素的內容框的大小:它的具體對象的大小被解析為對元素的使用寬度和高度的含有約束。
  • cover
    被替換的內容的尺寸卻使元件的整個內容框,以保持其長寬比其具體的對象的大小被解析為針對元素的使用的寬度和高度的蓋約束。
  • none
    被替換的內容的尺寸卻使元件的整個內容框,以保持其長寬比其具體的對象的大小被解析為針對元素的使用的寬度和高度的蓋約束。
  • scale-down
    內容的尺寸仿佛none或contain指定了,取將導致更小的具體對象的大小。

用法:

img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

如果想要相容性好點可以用下麵的方法,不過缺點就是圖片的自身尺寸要比容器大才行:

  <style>
    .exa1{
      width: 500px;
      height: 400px;
      margin: 0 auto;
      border: 1px solid #f00;
    }
    .exa1 img {
      display: block;
      max-width: 100%;
      max-height: 100%;
      position: relative;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
    }
  </style>
</head>
<body>
  <h5>圖片自適應寬度或高度100%</h5>
  <div class="exa1">
    <img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1513482866&di=b7de9d07063752ad42c09826014e5a8d&imgtype=jpg&er=1&src=http%3A%2F%2Fpic1.5442.com%2F2015%2F0305%2F07%2F001.jpg" alt="">
  </div>

</body>
</html>

效果圖如下:

圖片要鋪滿整個容器,但是不能變形

這裡只能用到object-fit的cover;不過有相容性問題。

img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

效果如下:
鋪滿


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • PS:我們在做安卓程式的時候,免不了會做一些圖形,自己可以選擇自定義view ,就是用Canvas畫,也可以用寫好的jar包,就是achartengine.jar,使用jar包的好處就快速繪製圖形,不用我們計算坐標等,計算坐標就會和數學結合,通過sin,cos等來計算,遇到3維那就更麻煩了,就像Op ...
  • PS:SharedPreferences只要稍微學過一點就會用,他本身通過創建一個Editor對象,來存儲提交,而editor可以存的格式為 他裡面可以存一個Set<String> HashSet是Java中非常常用的數據結構對象,HashSet是通過HashMap實現的,TreeSet是通過Tre ...
  • 一、概述 Glide是一個在Android端非常好的圖片緩衝工具,總體上來說,他有以下優點 使用簡單 自適應程度高 支持常見的圖片格式,如jpg,png等 支持多種數據源,網路,本地,資源,Assets等 高效的緩存策略,支持Memory和Disk圖片緩存策略,預設Bitmap格式採用RGB_565 ...
  • 時間:2017年12月10日 21:52:59 用途:此文章用於個人總結 css筆記1.CSS全稱為"層疊樣式表(Cascading Style Sheets)"2.CSS樣式的語法: 選擇符{屬性:值}3.CSS樣式代碼插入的三種形式:內聯/嵌入/外部 內聯式:就是把代碼寫在html標簽的行間樣式 ...
  • 萬事開頭難,一個好的Hello World程式可以節省我們好多的學習時間,幫助我們快速入門。Hello World程式之所以是入門必讀必會,就是因為其代碼量少,簡單易懂。但我覺得,還應該做到功能豐富,涉及的知識點多。這樣才是一個好的初學者入門指引程式。 之所以選擇Vue,不僅因為其流行,還因為其輕量 ...
  • 關於ES6模塊化 歷史上,JavaScript 一直沒有模塊(module)體系,無法將一個大程式拆分成互相依賴的小文件,再用簡單的方法拼裝起來。其他語言都有這項功能,比如 Ruby 的require、Python 的import,甚至就連 CSS 都有@import,但是 JavaScript 任 ...
  • 寫在前面 這個文章,展現的是一個實現Promise的思路,以及如何發現和處理問題的情境。 從現有的Promise分析 如果我們想要自己實現一個簡單的 ,那現有規範規定的 肯定是我們最好的參照。 我們先看下 怎麼使用: 來看下返回的 是什麼,以及它的結構是怎麼樣的: 再進行一些具體操作 從Promis ...
  • 1.(webpack)vue-cli構建的項目如何設置每個頁面的title 在路由里每個都添加一個meta 鉤子函數: 在main.js中添加如下代碼 2.vue項目中使用axios上傳圖片等文件 首先安裝axios:1.利用npm安裝npm install axios –save2.利用bower ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...