当前位置: 首页 > news >正文

CSS布局居中

1、把margin设置为auto,此方法只能进行水平的居中,且对浮动元素或绝对定位元素无效。

代码:

<style type="text/css">
    body{
        margin: 0;
        padding: 0;
    }
        #div1{
            background-color: red;
            width: 150px;
            height: 150px;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            margin-left: auto;
            margin-right: auto;
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
        </div>
    </div>
</body>

2、效果图同上

这个没什么好说的,只能对图片,按钮,文字等行内元素(display为inline或inline-block等)进行水平居中。但要说明的是在IE6、7这两个奇葩的浏览器中,它是能对任何元素进行水平居中的。

代码:

<style type="text/css">
    body{
        margin: 0;
        padding: 0;
    }
        #div1{
            background-color: red;
            width: 150px;
            height: 150px;
            text-align: center;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            display: inline-block;
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
        </div>
    </div>
</body>

3、使用line-height让单行的文字垂直居中

把文字的line-height设为文字父容器的高度,适用于只有一行文字的情况。

4、使用表格:table

如果你使用的是表格的话,那完全不用为各种居中问题而烦恼了,只要用到 td(也可能会用到 th)元素的 align="center" 以及 valign="middle" 这两个属性就可以完美的处理它里面内容的水平和垂直居中问题了,而且表格默认的就会对它里面的内容进行垂直居中。如果想在css中控制表格内容的居中,垂直居中可以使用 vertical-align:middle,至于水平居中,貌似css中是没有相对应的属性的,但是在IE6、7中我们可以使用text-align:center来对表格里的元素进行水平居中,IE8+以及谷歌、火狐等浏览器的text-align:center只对行内元素起作用,对块状元素无效。

 

5、使用display:table-cell来居中

对于那些不是表格的元素,我们可以通过display:table-cell 来把它模拟成一个表格单元格,这样就可以利用表格那很方便的居中特性了。例如:

但是,这种方法只能在IE8+、谷歌、火狐等浏览器上使用,IE6、IE7都无效。

代码:

<style type="text/css">
    body{
        margin: 0;
        padding: 0;
    }
        #div1{
            border: 1px dashed red;
            width: 150px;
            height: 150px;
            display: table-cell;
            /*控制水平居中*/
            text-align: center;
            /*控制垂直居中*/
            vertical-align: middle;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            display: inline-block;
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
            
        </div>
    </div>
</body>

那面所说的都是很基础的方法,自然不能称之为奇淫巧计,下面就来说一些需要使用一些技巧的居中方法。

6、使用绝对定位来进行居中

效果图1:

代码1:

<style type="text/css">
    body{
        margin: 0;
        padding: 0;
    }
        #div1{
            border: 2px dashed red;
            width: 150px;
            height: 150px;
            position: relative;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            position: absolute;
            /**
             * top、和left的计算问题
             * (152-70)/2=35
             */
            top: 41px;
            left: 41px;
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
            
        </div>
    </div>
</body>

效果图2:

代码2:

<style type="text/css">
    body{
        margin: 0;
        padding: 0;
    }
        #div1{
            border: 2px dashed red;
            width: 110px;
            height: 110px;
            position: relative;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            position: absolute;
            /**
             * margin-top、和margin-left的计算问题
             * -70/2=-35
             */
            left: 50%;
            top: 50%;
            margin-left: -35px;  //子元素宽度负的一半
            margin-top: -35px;   //子元素高度负的一半
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
            
        </div>
    </div>
</body>

如果只想实现一个方向的居中,则可以只使用left , margin-left 来实现水平居中,使用top , margin-top来实现垂直居中。

7、另一种使用绝对定位来居中的方法

此法同样只适用于那些我们已经知道它们的宽度或高度的元素,并且遗憾的是它只支持IE9+,谷歌,火狐等符合w3c标准的现代浏览器。
下面用一段代码来了解这种方法:

效果图

代码:

<style type="text/css">
        body{
            margin: 0;
            padding: 0;
        }
        #div1{
            border: 2px dashed red;
            width: 110px;
            height: 110px;
            position: relative;
        }
        #div2{
            background-color: black;
            width: 70px;
            height: 70px;
            position: absolute;
            /**
             * 此方法只适用高度宽度固定的
             */
            /*left、right必须配对出现控制水平方向*/
            left: 0;
            right: 0;
            /*top、bottom必须配对出现控制垂直方向*/
            top: 0;
            bottom: 0;
            /*下面这句也是必不可少的*/
            margin: auto;
        }
    </style>
</head>
<body>
    <div id="div1" class="classname">
        <div id="div2" class="classname">
            
        </div>
    </div>
</body>

这里如果不定义元素的宽和高的话,那么他的宽就会由left,right的值来决定,高会由top,bottom的值来决定,所以必须要设置元素的高和宽。同时如果改变left,right , top , bottom的值还能让元素向某个方向偏移,大家可以自己去尝试。

8、使用浮动配合相对定位来进行水平居中

此方法也是关于浮动元素怎么水平居中的解决方法,并且我们不需要知道需要居中的元素的宽度。

浮动居中的原理是:把浮动元素相对定位到父元素宽度50%的地方,但这个时候元素还不是居中的,而是比居中的那个位置多出了自身一半的宽度,这时就需要他里面的子元素再用一个相对定位,把那多出的自身一半的宽度拉回来,而因为相对定位正是相对于自身来定位的,所以自身一半的宽度只要把left 或 right 设为50%就可以得到了,因而不用知道自身的实际宽度是多少。

这种使用浮动配合相对定位来居中的方法,优点是不用知道要居中的元素的宽度,即使这个宽度是不断变化的也行;缺点是需要一个多余的元素来包裹要居中的元素。

看下代码:

http://www.cnblogs.com/2050/p/3392803.html

转载于:https://www.cnblogs.com/arvintang/p/5436254.html

相关文章:

  • Servlet和JSP关系浅析
  • selenium 获取某元素的 某属性 的值
  • BestCoder Round #81 (div.2) 1003 String
  • 2010年架构社区回顾:悠长的一年
  • 【VS开发】使用VS2010创建MFC ActiveX工程项目
  • Java Resource路径小结
  • 在ubuntu 15.04下安装VMware Tools
  • ZeroMQ(java)中监控Socket
  • hdu1418 欧拉公式
  • S3C2440-DMA
  • 冲刺第三天
  • 落花流水又一年
  • 九、oracle 事务
  • 路由器to路由器
  • 【问题】background:url(imagePath)不能显示图片
  • 自己简单写的 事件订阅机制
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • ES6语法详解(一)
  • iBatis和MyBatis在使用ResultMap对应关系时的区别
  • java概述
  • MYSQL 的 IF 函数
  • Spark学习笔记之相关记录
  • Terraform入门 - 3. 变更基础设施
  • Vue UI框架库开发介绍
  • 半理解系列--Promise的进化史
  • 基于HAProxy的高性能缓存服务器nuster
  • 聊聊redis的数据结构的应用
  • 如何将自己的网站分享到QQ空间,微信,微博等等
  • 携程小程序初体验
  • 一个项目push到多个远程Git仓库
  • 译有关态射的一切
  • 组复制官方翻译九、Group Replication Technical Details
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • (Arcgis)Python编程批量将HDF5文件转换为TIFF格式并应用地理转换和投影信息
  • (pytorch进阶之路)CLIP模型 实现图像多模态检索任务
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (附源码)ssm经济信息门户网站 毕业设计 141634
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (论文阅读30/100)Convolutional Pose Machines
  • (强烈推荐)移动端音视频从零到上手(下)
  • (原創) 系統分析和系統設計有什麼差別? (OO)
  • (转) Android中ViewStub组件使用
  • (转)shell调试方法
  • .bat批处理(四):路径相关%cd%和%~dp0的区别
  • .NET 4 并行(多核)“.NET研究”编程系列之二 从Task开始
  • .Net Core 中间件验签
  • .one4-V-XXXXXXXX勒索病毒数据怎么处理|数据解密恢复
  • @RestControllerAdvice异常统一处理类失效原因
  • @Tag和@Operation标签失效问题。SpringDoc 2.2.0(OpenApi 3)和Spring Boot 3.1.1集成
  • [Android] Amazon 的 android 音视频开发文档
  • [BUAA软工]第一次博客作业---阅读《构建之法》
  • [BZOJ3223]文艺平衡树
  • [C#]科学计数法(scientific notation)显示为正常数字
  • [CF482B]Interesting Array
  • [Codeforces] combinatorics (R1600) Part.2