水平居中是常用的几种布局方式之一。主要分为行内元素的居中,块元素的居中。块元素的居中还分为固定宽度的居中,不定宽度的居中。行内元素的居中,使用text-align:center就可以实现,已知宽度的块元素的居中,使用绝对定位以及设置
margin为宽的一半的负值就可以实现。但是不定宽度的居中比起上面两种更常用,也更复杂,我们常常需要在分页的页码展示等地方用到不定宽居中,使用起来更方便,下面来研究下常用的几种块元素的水平居中。

1.标签嵌套偏移

实现原理:

联想到固定宽度的居中的实现:先偏移到屏幕中央,在设置其margin方向偏移宽的一半。那么能不能想到一种方法,借用这种思路,先偏移50%到屏幕的右半部分,然后在反方向偏移回来?实现起来比较困难的点是不知道这个宽度是多少。又想到只要让其父宽度和子宽度相等,然后用百分数就可以解决。那么怎么让其父宽度和字宽度一样呢?巧借float具有的包裹性:父元素如果漂浮了,并且没有设置宽高,那么将尽量包裹子元素。

实现代码:

XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8">  
  5.     <title>不定宽度水平居中</title>  
  6.     <style>  
  7.         body{  
  8.             background-color: #e5da31;  
  9.         }  
  10.         .container{  
  11.             position: absolute;   /*脱离文档流,其宽度将由子元素的宽度决定*/  
  12.             left:50%;  
  13.         }  
  14.         .content{  
  15.             position: absolute;  
  16.             left:-50%;  
  17.             background-color: #2ecc71;  
  18.         }  
  19.     </style>  
  20. </head>  
  21. <body>  
  22. <div class="container">  
  23.     <div class="content">标签嵌套</div>  
  24. </div>  
  25. </body>  
  26. </html>  

实现效果:

关于css水平居中的小小探讨

优点与缺点: 缺点很明显,需要自己写和文档内容无关的标签,多打了那么几行代码兼容性良好,在ie6+浏览器上查看没有问题 2.flex-box布局 实现原理: 先定义一个flex容器,然后设置其内容对齐方式为中间对齐 XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8">  
  5.     <title>不定宽度水平居中</title>  
  6.     <style>  
  7.         body {  
  8.             background-color: #e5da31;  
  9.         }  
  10.         .container {  
  11.             display: flex;  /*定义一个flex容器*/  
  12.             justify-content: center;  /*定义容器的空间没有被全部占用时,内容的对其方式*/  
  13.         }  
  14.         .content{  
  15.             background-color: #2ecc71;  
  16.         }  
  17.     </style>  
  18. </head>  
  19. <body>  
  20. <div class="container">  
  21.     <div class="content">标签嵌套</div>  
  22. </div>  
  23. </body>  
  24. </html>  
实现效果: 关于css水平居中的小小探讨 优缺点分析: 实现起来最简单,但是呢,因为flex的兼容性不好,当要兼容低阶浏览器时慎重使用。 3.内联布局 实现原理: text-align:center可以让行内元素水平居中,如果改变块元素为行内元素,在使用text-align就可以实现水平居中。 实现代码: XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8">  
  5.     <title>不定宽度水平居中</title>  
  6.     <style>  
  7.         body{  
  8.             background-color: #e5da31;  
  9.         }  
  10.         .container{  
  11.           text-align:center;  
  12.         }  
  13.         .content{  
  14.         display: inline;  
  15.             background-color: #2ecc71;  
  16.         }  
  17.     </style>  
  18. </head>  
  19. <body>  
  20. <div class="container">  
  21.     <div class="content">标签嵌套</div>  
  22. </div>  
  23. </body>  
  24. </html>  

实现效果:

关于css水平居中的小小探讨 

优缺点分析:

用本来是修饰文字对齐方式的text-align来实现水平居中总感觉有点别扭,这块外面的container也先多余,但是为了不影响body内其他元素的局部,暂且如此。另外兼容性不错,在ie6+可以正常显示。

以上就是小编为大家带来的关于css水平居中的小小探讨全部内容了,希望大家多多支持~

原文地址:http://www.cnblogs.com/shibazijiang/archive/2016/06/28/5624831.html

标签:
css,水平,居中

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
千金楼资源网 Copyright www.htabc.com

评论“关于css水平居中的小小探讨”

暂无“关于css水平居中的小小探讨”评论...

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?