关于css水平居中的小小探讨
建站知识 2021-07-03 08:15www.168986.cn长沙网站建设
水平居中是常用的几种布局方式之一。主要分为行内元素的居中,块元素的居中。块元素的居中还分为固定宽度的居中,不定宽度的居中。行内元素的居中,使用text-align:center就可以实现,已知宽度的块元素的居中,使用绝对定位以及设置
margin为宽的一半的负值就可以实现。不定宽度的居中比起上面两种更常用,也更复杂,我们常常需要在分页的页码展示等地方用到不定宽居中,使用起来更方便,狼蚁网站SEO优化来研究下常用的几种块元素的水平居中。
1.标签嵌套偏移
实现原理
联想到固定宽度的居中的实现先偏移到屏幕中央,在设置其margin方向偏移宽的一半。那么能不能想到一种方法,借用这种思路,先偏移50%到屏幕的右半部分,然后在反方向偏移回来?实现起来比较困难的点是不知道这个宽度是多少。又想到只要让其父宽度和子宽度相等,然后用百分数就可以解决。那么怎么让其父宽度和字宽度一样呢?巧借float具有的包裹性父元素如果漂浮了,并且没有设置宽高,那么将尽量包裹子元素。
实现代码
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>不定宽度水平居中</title>
- <style>
- body{
- background-color: #e5da31;
- }
- .container{
- position: absolute; /脱离文档流,其宽度将由子元素的宽度决定/
- left:50%;
- }
- .content{
- position: absolute;
- left:-50%;
- background-color: #2e71;
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="content">标签嵌套</div>
- </div>
- </body>
- </html>
实现效果
优点与缺点
缺点很明显,需要自己写和文档内容无关的标签,多打了那么几行代码兼容性良好,在ie6+浏览器上查看没有问题
2.flex-box布局
实现原理
先定义一个flex容器,然后设置其内容对齐方式为中间对齐
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>不定宽度水平居中</title>
- <style>
- body {
- background-color: #e5da31;
- }
- .container {
- display: flex; /定义一个flex容器/
- justify-content: center; /定义容器的空间没有被全部占用时,内容的对其方式/
- }
- .content{
- background-color: #2e71;
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="content">标签嵌套</div>
- </div>
- </body>
- </html>
实现效果
优缺点分析
实现起来最简单,呢,因为flex的兼容性不好,当要兼容低阶浏览器时慎重使用。
3.内联布局
实现原理
text-align:center可以让行内元素水平居中,如果改变块元素为行内元素,在使用text-align就可以实现水平居中。
实现代码
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>不定宽度水平居中</title>
- <style>
- body{
- background-color: #e5da31;
- }
- .container{
- text-align:center;
- }
- .content{
- display: inline;
- background-color: #2e71;
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="content">标签嵌套</div>
- </div>
- </body>
- </html>
实现效果
优缺点分析
用本来是修饰文字对齐方式的text-align来实现水平居中总感觉有点别扭,这块外面的container也先多余,为了不影响body内其他元素的局部,暂且如此。兼容性不错,在ie6+可以正常显示。
以上就是长沙网络推广为大家带来的关于css水平居中的小小探讨全部内容了,希望大家多多支持狼蚁SEO~
原文地址
上一篇:浅谈css命名规则(新手必看)
下一篇:纯CSS绘制三角形箭头图案技术解析
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML