Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 国产一区二区网站,中文一区二区,尤物精品国产第一福利三区

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          CSS 垂直居中方法匯總

          直居中-父元素高度確定的單行文本

          父元素高度確定的單行文本的豎直居中的方法是通過設置父元素的height和line-height高度一致來實現的。如下代碼:

          <div class="container">
          hi,imooc!
          </div>

          css代碼:

          <style>
              .container{
              height:100px;
              line-height:100px; /* 僅能用于單行文本 */
              background:#999;
          }
          </style>

          垂直居中-圖片以及行內塊元素

          <div class="container">
          <img src="imgegs/icon.png" />
          </div>

          css代碼:

          <style>
          .container{
              height:100px;
              background:#999;
          }
          .container img{
              vertical-align:middle;
          }
          </style>

          垂直居中-父元素高度確定的多行文本(方法一)

          父元素高度確定的多行文本、圖片、塊狀元素的豎直居中的方法有兩種:

          方法一:使用插入table(包括tbody、tr、td)標簽, 同時設置vertical-align:middle。

          說到豎直居中,css中有一個用于豎直居中的屬性vertical-align,但這個樣式只有在父元素為td 或th時,才會生效。所以又要插入table標簽了。

          下面看一下例子:

          html代碼:

          <body>
          <table><tbody><tr><td class="wrap">
          <div>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          </div>
          </td></tr></tbody></table>
          </body>

          css代碼:

          table td{height:500px;background:#ccc}

          因為td標簽默認情況下就默認設置了vertical-align為middle, 所以我們不需要顯式地設置了。

          垂直居中-父元素高度確定的多行文本(方法二)

          在chrome、firefox及IE8以上的瀏覽器下可以設置塊級元素的display為table-cell, 激活vertical-align屬性, 但注意IE6、7并不支持這個樣式。

          html代碼:

          <div class="container">
          <div>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          </div>
          </div>

          css代碼:

          <style>
          .container{
              height:300px;
              background:#ccc;
              display:table-cell; /*IE8以上及Chrome、Firefox*/
              vertical-align:middle; /*IE8以上及Chrome、Firefox*/
          }
          </style>

          這種方法的好處是不用添加多余的無意義的標簽,但缺點也很明顯,它的兼容性不是很好,不兼容 IE6、7。

          垂直居中--方法三

          <!DOCTYPE html>
          <html lang="zh">
          <head>
          <meta charset="UTF-8" />
          <meta name="viewport" content="width=device-width, initial-scale=1.0" />
          <meta http-equiv="X-UA-Compatible" content="ie=edge" />
          <title>Document</title>
          <style type="text/css">
          *{
              margin: 0;
              padding: 0;
          }
          div{
              width: 400px;
              height: 300px;
              background-color: orange;
          }
          /*
          * 思路一:left:50%;top:50%;margin-left: -200px;margin-top: -150px;
          * 思路二:left:0;top:0;right:0;bottom:0;margin:auto;
          * */
          
          div{
              position: absolute;
              left: 50%;
              top: 50%;
              transform: translate(-50%,-50%); /* 平移 */
          }
          </style>
          </head>
          <body>
          <div></div>
          </body>
          </html>

          實例1:將內層div的文本垂直居中

          <!DOCTYPE HTML>
          <html>
          <head>
          <meta charset="utf-8">
          <title>父元素高度確定的多行文本</title>
          <style>
          .container{
              height:300px;
              background:#ccc;
              display:table-cell; /*IE8以上及Chrome、Firefox*/
              vertical-align:middle; /*IE8以上及Chrome、Firefox*/
          }
          </style>
          </head>
          <body>
          <div class="container">
          <div>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          <p>看我是否可以居中。</p>
          </div>
          </div>
          <!--下面是代碼任務區-->
          </body>
          </html>

          實例2:將內層垂直居中、外層水平居中

          <!doctype html>
          <html>
          <head>
          <meta charset="utf-8">
          <title>無標題文檔</title>
          <style type="text/css">
          #content{
              width:300px;
              height:300px;
              border:#000 solid 1px;
              margin:auto;
              display:table;
          }
          #wenzi{
              border:#F00 solid 1px;
              text-align:center;
              display:table-cell;
              vertical-align: middle;
          }
          </style>
          </head>
          <body>
          <div id="content">
          <div id="wenzi">
          鋤禾日當午,<br>
          汗滴禾下土。<br>
          誰知盤中餐,<br>
          粒粒皆辛苦。<br>
          </div>
          </div>
          </body>
          </html>

          實例3: 使用絕對定位垂直居中

          <!DOCTYPE html>
          <html lang="en">
          <head>
          <meta charset="UTF-8" />
          <title>Document</title>
          <style type="text/css">
          *{
              margin: 0;
              padding: 0;
          }
          div{
              width: 220px;
              height: 280px;
              background: url("img/王思聰.jpg");
              position: absolute;
              left: 50%;
              top: 50%;
              margin-left: -110px;
              margin-top: -140px;
          }
          </style>
          </head>
          <body>
          <!--
          行內元素(文本)->水平垂直居中
          text-align: center;
          line-height: height;
          -->
          <!--
          塊元素->水平垂直居中
          margin: 0 auto;
          -->
          <div></div>
          </body>
          </html>

          實例4: 使用絕對定位垂直居中

          <!DOCTYPE html>
          <html lang="en">
          <head>
          <meta charset="UTF-8" />
          <title>Document</title>
          <style type="text/css">
          *{
              margin: 0;
              padding: 0;
          }
          div{
              width: 600px;
              height: 200px;
              padding: 10px 20px;
              border: 1px solid #000;
              border-radius: 5px;
              /* 下面這種寫法也可以讓一個盒子居中 */
              position: absolute;
              left: 0;
              right: 0;
              top: 0;
              bottom: 0;
              margin: auto;
          }
          </style>
          </head>
          <body>
          <div>您確定刪除:重慶萬州公交墜江事件結果公布后,司乘糾紛和公交駕駛安全問題成為人們熱議的焦點,如何預防和避免惡性結果的發生,才是問題的關鍵。“鼓勵市民舉報,并對勇于制止干擾公交車正常行駛違法行為的公民予以獎勵。”昨日下午,西安市公安局公共交通分局召開媒體通氣會,通報西安相關安全舉措。這條消息嗎</div>
          </body>
          </html>

          絕對定位(固定定位)之后, 所有標準流的規則, 都不適用了。所以margin:0 auto; 失效。

          解決辦法:left:50%; margin-left:負的寬度的一半。(三句話)

          div{
          width: 600px;
          height: 60px;
          position: absolute;  /* → 第一句  */
          left: 50%;   //   /*  → 第二句   */ 
          top: 0;
          margin-left: -300px;    /*→ 第三句。寬度的一半*/
          }

          實例4:使用絕對定位和margin:auto垂直居中

          網站的布局是一個網站設計的根本,CSS的Grid布局已經成為了未來網站布局的基本方式。

          今天這篇文章我們通過圖文,一起看看如何自己實現Grid布局方式。

          CSS

          第一個Grid布局

          首先我們看看最基本的Grid布局是什么樣的,HTML頁面的代碼如下所示。

          HTML代碼

          然后設置其CSS屬性,這里主要展示容器的CSS屬性,給子元素添加的color屬性就不在這里展示了。

          CSS屬性

          在頁面上看到的效果如下,目前因為沒有對子div元素做任何設置,會自動將子div沿垂直方向排列。

          頁面效果

          設置行和列

          為了讓外層的div(wrapper)為一個網格容器,需要設置其行數和列數,就像一個表格一樣。

          此時就需要用到grid-template-columns和grid-template-rows兩個屬性值。

          • grid-template-columns

          用于設置網格容器的列屬性,其實就相當于列的寬度。當我們需要幾列展示時,就設置幾個值,這個屬性可以接收具體數值比如100px,也可以接收百分比值,表示占據容器的寬度。

          需要注意的是:當給容器設定了寬度時,grid-template-columns設定的百分比值是以容器的寬度值為基礎計算的。如果未設置寬度時,會一直向上追溯到設置了寬度的父容器,直到body元素。

          比如我們設置了以下的CSS屬性。

          CSS屬性

          可以看出三列寬度加起來的百分比值為120%,而且wrapper容器并未設置寬度,會一直向上追溯到body元素,這樣三列的總寬度已經超過了body的寬度,因此會出現滾動條。

          頁面效果

          • grid-template-rows

          用于設置網格容器的行屬性,其實就相當于行的高度,其特性與grid-template-columns屬性類似。

          下面簡單修改grid-template-columns和grid-template-rows兩個屬性的值。

          CSS值

          得到的效果圖如下所示。

          效果圖

          放置子元素

          接下來我們看看別的情況,通過CSS屬性設置3*3的網格。

          CSS屬性

          在頁面上的呈現方式如下所示。

          頁面呈現

          從頁面上看我們看不出有什么問題,但是打開控制臺后可以發現,這個網格已經占據了3*3的空間。它后面的元素只能排列在所有的網格后面。

          頁面實際情況

          不規則排列

          當我們需要得到特殊的排列方式,比如占滿整行,占滿整列,二三行合并等等。

          這就需要用到grid-column和grid-row屬性,表示行網線和列網線的序號。通過設置start和end值,來進行網格的合并。

          網線序號

          我們重新給wrapper容器內部的div添加class類。

          HTML代碼

          然后添加以下的CSS代碼,給不同的網格特定的行號和列號。

          CSS代碼

          最終得到的效果圖如下所示。

          頁面效果圖

          結束語

          今天這篇文章介紹了CSS中Grid布局的基礎知識,應該可以很快掌握,其他的復雜點的網格布局大家也可以自己去嘗試。

          做不是響應式的網頁中,根據各自的需求,一般都給網頁設定一定的版心,有時會遇到下面這個問題!

          有一個通欄的100%上有背景色的DIV,然后版心設置1200px居中顯示內容,當這網頁隨著瀏覽器窗口縮小后,縮小到出現橫向滾動條,然后往右拉滾動條的話,這個含有背景色的DIV就會出現留白空隙!今天就來說說如何解決該問題!

          先舉個例子:

          縮小瀏覽器出現滾動條后效果圖:

          把橫向滾動條向右拉,超出視口的部分丟失了背景色:

          解決方法:

          在外層div上面設置min-width: 1200px;即可解決

          外層div的寬度是100%,就是視口的大小,當視口被拉窄到小于內層div的寬度1200px時,比如800px,此時外層div寬度為800px,內層div寬度依然為1200px,而css中只設置了外層div有背景色,所以說只有800px那一部分會顯示背景色,而超出視口的部分是屬于內層div的,內層沒有設置背景色,所以是空白!


          主站蜘蛛池模板: 区三区激情福利综合中文字幕在线一区亚洲视频1 | 国模无码人体一区二区| 日韩精品无码一区二区三区不卡 | 日韩精品无码久久一区二区三| 国产一区二区在线看| 亚洲一区无码精品色| 天堂不卡一区二区视频在线观看 | 国产综合无码一区二区色蜜蜜| 亚洲国产精品自在线一区二区 | 91午夜精品亚洲一区二区三区| 国产色情一区二区三区在线播放 | 亚洲av乱码一区二区三区按摩 | 色天使亚洲综合一区二区| 日本片免费观看一区二区| 无码少妇一区二区三区| 国产精品日本一区二区不卡视频 | 无码精品人妻一区二区三区免费看| 无码毛片一区二区三区中文字幕 | 无码欧精品亚洲日韩一区| 中文字幕精品亚洲无线码一区| 搜日本一区二区三区免费高清视频| 日美欧韩一区二去三区| 国产视频一区二区在线观看| 国产一区二区不卡老阿姨| 伊人无码精品久久一区二区| 亚洲综合一区国产精品| 日本片免费观看一区二区| 一区二区三区高清| 成人免费视频一区二区三区| 国产免费一区二区三区VR| 国产伦精品一区二区三区在线观看 | 国产aⅴ一区二区| 亚洲国产激情一区二区三区| 久久精品无码一区二区日韩AV| 中文国产成人精品久久一区| 狠狠色婷婷久久一区二区 | 亚洲国产精品一区二区第一页免| 国产情侣一区二区三区| 中文字幕Av一区乱码| 久久无码人妻一区二区三区午夜 | 精品一区二区三区免费观看|