侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

CSS 实现垂直居中的几种方法(必看)

前端  /  管理员 发布于 7年前   427

最近在学关系型数据库相关,MySQL 和 Postgre,捎带着学了 PHP,为了练手这几天就忙着自己搭博客,项目部署在某云上,该云算是良心,给的空间自己搭博客用足够了。本来想着每日一bo的,所以有的时候实在来不及就只能隔天更新了。以后尽量发点东西出来,等博客搭完写一写 SQL 数据库基础相关的分享,给跟我一样的小白道友们做下参考,大神请直接无视~

说到居中,很多人第一反应应该是水平居中,说到水平居中,肯定道友们有一万种方法做到,CSS3 的FlexBox更是强大到没朋友。但是良辰今天想聊的是 CSS 垂直居中的方法,下面是萌萌的分割线。神马?你敢说不萌?

•方式一 :table 布局方法

•直接上🐴:

XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4. <meta charset="UTF-8">  
  5. <title>Title</title>  
  6. </head>  
  7. <body>  
  8. <style>  
  9. .container{   
  10. width: 200px;   
  11. height: 200px;   
  12. font-weight:bold;">deepskyblue;   
  13. display: table;   
  14. }   
  15. .cell{   
  16. display: table-cell;   
  17. vertical-align: middle;   
  18. font-weight:bold;">lawngreen;   
  19. }   
  20. .content{   
  21. font-weight:bold;">yellow;   
  22. }   
  23. </style>  
  24. <div class="container">  
  25. <div class="cell">  
  26. <div class="content">  
  27. Content   
  28. </div>  
  29. </div>  
  30. </div>  
  31. </body>  
  32. </html>   

效果:

  • •分析

    •优点:content 高度可以动态改变,无须担心父级容器高度不够被截断;

    •缺点:IE8 还没搞定。  

    •方式二:布局对象固定高度

    CSS Code复制内容到剪贴板
    1. <!DOCTYPE html>   
    2. <html lang="en">   
    3. <head>   
    4.     <meta charset="UTF-8">   
    5.     <title>vertical-center</title>   
    6. </head>   
    7. <body>   
    8.     <style>   
    9.         .container{   
    10.             width: 200px;   
    11.             height: 200px;   
    12.             background-color: #003366;   
    13.             position: relative;   
    14.             text-align: center;   
    15.             display: table;   
    16.         }   
    17.         .content{   
    18.             width:100px;   
    19.             height: 100px;   
    20.             background-color: yellow;   
    21.             position: absolute;   
    22.             top:50%;   
    23.             margin-top: -50px;   
    24.          left:50%;   
    25.           margin-left:-50px;     
    26.         }   
    27.         .point{   
    28.             width:50px;   
    29.             height: 50px;   
    30.             position: absolute;   
    31.             top: 50%;   
    32.             margin-top: -25px;   
    33.             left:50%;   
    34.             margin-left:-50px;   
    35.             background-color: green;   
    36.         }   
    37.   
    38.     </style>   
    39.   
    40.     <div class="container">   
    41.         <div class="content">   
    42.             <div class="point">   
    43.                 point goes here.   
    44.             </div>   
    45.         </div>   
    46.     </div>   
    47. </body>   
    48. </html>  

    •就这样,我们实现了垂直和水平的居中

  • 上面提到的方法,都有局限性,下面介绍一种通用的方法,不过是 CSS3实现的,但是通用。

    XML/HTML Code复制内容到剪贴板
    1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
    2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">  
    3. <head>  
    4.     <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">  
    5.     <title>haorooms不固定高度div写法</title>  
    6.   
    7.     <style>  
    8. .center {   
    9.   position: fixed;   
    10.   top: 50%;   
    11.   left: 50%;   
    12.   background-color: #000;   
    13.   width:50%;   
    14.   height: 50%;   
    15. -webkit-transform: translateX(-50%) translateY(-50%);   
    16. }   
    17.   
    18.   
    19.     </style>  
    20. </head>  
    21. <body>  
    22.     <div class="center"></div>  
    23. </body>  
    24. </html>  

    •看吧,我们只是吧 margin 变成translate,其他浏览器的写法如下:

    -webkit-transform: translateX(-50%) translateY(-50%);

    -moz-transform: translateX(-50%) translateY(-50%);

    -ms-transform: translateX(-50%) translateY(-50%);

    transform: translateX(-50%) translateY(-50%);•justify-content:center;//子元素水平居中

    align-items:center;//子元素垂直居中

    display:-webkit-flex; 就先写这么多吧,先吃饭去啦~

    以上这篇CSS 实现垂直居中的几种方法(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

    原文地址:http://www.cnblogs.com/Slim-Shady/archive/2016/06/13/5582324.html


  • 上一条:
    css权威指南--笔记(必看)
    下一条:
    CSS3实现翘边的阴影效果的代码示例
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客