首页 web前端 css教程 css3如何让盒子水平居中

css3如何让盒子水平居中

Jan 20, 2022 pm 06:32 PM
css

css3让盒子水平居中的方法:1、使用margin属性,给盒子元素添加“margin: 0 auto;”样式即可水平居中;2、利用flex弹性布局来实现水平居中;3、利用position和transform属性实现水平居中。

css3如何让盒子水平居中

本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。

在CSS中如何让盒子水平居中是很常见的面试题,盒子居中是相对于父元素来说的,因此我们让盒子居中时,往往采用嵌套的方式,让父盒子套着子盒子 。

 在父子盒子嵌套下,让子盒子居中的方式:

  • 第一种方法:margin: 0 auto,使用边框,但是margin使用会影响其他盒子的使用,不太推荐使用;

  • 第二种方法:position, 使用定位,子绝父相,再left:50%,margin-left:负的盒子宽度的一半,这是最常用的方法;

  • 第三种方法:flex,弹性布局,让子盒子居中,但是样式要写在父盒子中,display:flex,just-content:center;

  • 第四种方法:在position基础上,把margin-left换成CSS3中的transform:translate(-50px);

  • 第五种方法:在position的基础上,只保留子绝父相,然后在子盒子中加上margin:auto、left:0、right:0;

    补充:在第五种方法上,加上top:0,bottom:0,可以实现垂直和水平都居中

<div id="father">
    <div id="son"></div>
</div>
<style>
    #father{
        width: 400px;
        height: 200px;
        border: 3px solid pink;
    }
    #son{
        width: 100px;
        height: 100px;
        border: 2px solid red;
    }
</style>

使用margin实现水平居中:

<style>
#father{
    width: 400px;
    height: 200px;
    border: 3px solid pink;
    margin: 30px auto; /* 让父元素相对于body居中 */
}
#son{
    width: 100px;
    height: 100px;
    border: 2px solid red;
    margin: 0 auto;/* 让子元素相对于father居中 */
}
</style>

使用定位,子绝父相,再left:50%,margin-left:负的盒子宽度的一半:

<style>
#father{
    width: 400px;
    height: 200px;
    border: 3px solid pink;
    margin: 0 auto;
    position: relative;
}
#son{
    width: 100px;
    height: 100px;
    border: 2px solid red;
    position: absolute;
    left: 50%;
    margin-left: -50px;
}
</style>

flex,弹性布局,让子盒子居中,但是样式要写在父盒子中:

<style>
#father{
    width: 400px;
    height: 200px;
    border: 3px solid pink;
    margin: 0 auto;
    display: flex;
    justify-content: center;
}
#son{
    width: 100px;
    height: 100px;
    border: 2px solid red;
}
</style>

在position的基础上,只保留子绝父相,然后在子盒子中加上margin:auto、left:0、right:0:

<style>
#father{
    width: 400px;
    height: 200px;
    border: 3px solid pink;
    margin: 0 auto;
    position: relative;
}
#son{
    width: 100px;
    height: 100px;
    border: 2px solid red;
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
}
</style>

以上几种方法都可以实现盒子的水平居中,如果大家有其它优(奇)秀(葩)方法,欢迎交流鸭!

第五种方法补充:再加上top:0,bottom:0可以实现水平和垂直都居中 :

<style>
#father{
    width: 400px;
    height: 200px;
    border: 3px solid pink;
    margin: 0 auto;
    position: relative;
}
#son{
    width: 100px;
    height: 100px;
    border: 2px solid red;
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
</style>

(学习视频分享:css视频教程

以上是css3如何让盒子水平居中的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

PHP教程
1582
276
如何在CSS中使用过滤器属性 如何在CSS中使用过滤器属性 Aug 11, 2025 pm 05:29 PM

ThecssfilterPropertyAllowSeffectSlikeSlikeBlur,亮度,亮度和格雷斯级倾向于directliectlytohtmlelements.1)usethesyntaxfilter:filter-finction(value)to applyfeffs.2)to applyeffeffss.2)combinemultfielterspacepacepacepacepaceepaceepaceepaceepaceeparity,e.g.g.g.,blimtrur(2px)blirtrur(2px),2pxcx e.g.2pxcx,blimur(2pxcx)

如何更改CSS中的列表样式 如何更改CSS中的列表样式 Aug 17, 2025 am 10:04 AM

要更改CSS列表样式,首先使用list-style-type改变项目符号或编号样式,1.使用list-style-type设置ul的项目符号为disc、circle或square,ol的编号为decimal、lower-alpha、upper-alpha、lower-roman或upper-roman,2.用list-style:none完全移除标记,3.使用list-style-image:url('bullet.png')替换为自定义图像,4.通过list-style-position:in

如何使用CSS创建垂直线 如何使用CSS创建垂直线 Aug 11, 2025 pm 12:49 PM

使用带边框的div可快速创建垂直线,通过设置border-left和height定义样式和高度;2.利用::before或::after伪元素可在无额外HTML标签的情况下添加垂直线,适合装饰性分隔;3.在Flexbox布局中,通过设置divider类的宽度和背景色,可实现弹性容器间的自适应垂直分隔线;4.在CSSGrid中,将垂直线作为独立列(如auto宽度列)插入网格布局,适用于响应式设计;应根据具体布局需求选择最合适的方法,确保结构简洁且易于维护。

如何在CSS中创建虚线边框 如何在CSS中创建虚线边框 Aug 15, 2025 am 04:56 AM

使用CSS创建点状边框只需设置border属性为dotted即可,例如“border:3pxdotted#000”可为元素添加3像素宽的黑色点状边框,通过调整border-width可改变点的大小,较宽的边框产生更大的点,且可单独为某一边设置点状边框如“border-top:2pxdottedred”,点状边框适用于div、input等块级元素,常用于焦点状态或可编辑区域以提升可访问性,需注意颜色对比度,同时区别于dashed的短线样式,dotted呈现圆形点状,该特性在所有主流浏览器中均被广泛

如何使用CSS创建响应性的推荐滑块 如何使用CSS创建响应性的推荐滑块 Aug 12, 2025 am 09:42 AM

使用纯CSS创建响应式自动轮播的推荐语滑块是可行的,只需结合HTML结构、Flexbox布局和CSS动画。2.首先构建包含多个推荐语项的语义化HTML容器,每个.item包含引用内容和作者信息。3.通过设置父容器display:flex、width:300%(三张幻灯片)并应用overflow:hidden实现横向排列。4.利用@keyframes定义从0%到-100%的translateX变换,配合animation:scroll15slinearinfinite实现无缝自动滚动。5.添加媒体

如何更改CSS中的光标 如何更改CSS中的光标 Aug 16, 2025 am 05:00 AM

Usebuilt-incursortypeslikepointer,help,ornot-allowedtoprovideimmediatevisualfeedbackfordifferentinteractiveelements.2.ApplycustomcursorimageswiththecursorpropertyusingaURL,optionallyspecifyingahotspotandalwaysincludingafallbacklikeautoorpointer.3.Fol

如何使用CSS创建分屏布局 如何使用CSS创建分屏布局 Aug 11, 2025 pm 10:59 PM

使用CSS创建分屏布局可通过Flexbox实现,首先将容器设为display:flex并设置高度为100vh,通过flex:1使子元素均分空间,水平布局默认即可,垂直布局需设置flex-direction:column,配合媒体查询@media(max-width:768px)可实现移动端堆叠响应式效果,若需固定侧边栏则给其设置固定宽度,主内容区用flex:1自适应剩余空间,同时建议全局使用box-sizing:border-box以避免padding影响布局,最终实现简洁且响应式的分屏设计。

CSS:nth-child()选择器示例 CSS:nth-child()选择器示例 Aug 11, 2025 pm 11:22 PM

:nth-child()用于根据元素在同级中的位置来选中并样式化,常用于创建交替样式或特定模式;1.使用even和odd关键字可实现隔行变色,如li:nth-child(even)设置偶数项背景为浅灰色;2.使用an b公式可精确控制选中规律,如3n 1选中第1、4、7等项;3.特殊模式如-n 3可选中前3个子元素;4.注意nth-child从1开始计数且计算所有同级元素,若需仅按同类元素计数应使用nth-of-type()。

See all articles