首页 > 开发 > CSS > 正文

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

2024-07-11 08:32:44
字体:
来源:转载
供稿:网友

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

1.标签嵌套偏移

实现原理:

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

实现代码:

XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>   <html lang="en">  
  2. <head>       <meta charset="UTF-8">  
  3.     <title>不定宽度水平居中</title>       <style>  
  4.         body{               background-color: #e5da31;  
  5.         }           .container{  
  6.             position: absolute;   /*脱离文档流,其宽度将由子元素的宽度决定*/               left:50%;  
  7.         }           .content{  
  8.             position: absolute;               left:-50%;  
  9.             background-color: #2ecc71;           }  
  10.     </style>   </head>  
  11. <body>   <div class="container">  
  12.     <div class="content">标签嵌套</div>   </div>  
  13. </body>   </html>  
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表