返回顶部
首页 > 资讯 > 前端开发 > html >CSS中怎么实现DIV容器水平居中
  • 295
分享到

CSS中怎么实现DIV容器水平居中

2024-04-02 19:04:59 295人浏览 独家记忆
摘要

这篇文章主要介绍“CSS中怎么实现DIV容器水平居中”,在日常操作中,相信很多人在CSS中怎么实现DIV容器水平居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么

这篇文章主要介绍“CSS中怎么实现DIV容器水平居中”,在日常操作中,相信很多人在CSS中怎么实现DIV容器水平居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么实现DIV容器水平居中”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

DIV CSS教程:实现DIV容器水平居中的方法

WEB标准中的页面布局是使用DIV配合CSS来实现的。这其中最常用到的就是使整个页面水平居中的效果,这是在页面布局中基本,也是最应该首先掌握的知识。不过,还是经常会有人问到这个问题,在这里我简单总结一下使用DIV和CSS实现页面水平居中的方法:

一、margin:auto0与text-aligh:center

在现代浏览器(如InternetExplorer7、Firefox、Opera等)现代浏览器实现水平居中的方法很简单,只要设定到左右两侧的空白为自动即可。意即:

ExampleSourceCode

#wrap{margin:0auto;}

上面这段代码的意思是说使wrap这个DIV到左右两侧的距离自动设置,上下为0(可以为任意)。请在现代浏览器(如InternetExplorer7、Firefox、Opera等)中运行现在的代码:

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  "Http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <title>52CSS.comtitle> <metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=UTF-8"/> <styletypestyletype="text/css"> DIV#wrap{   width:760px;   margin:0auto;   border:1pxsolid#333;   background-color:#ccc;  }  style> head>  <body> <DIVidDIVid="wrap">

在Firefox等现代浏览器设定页面元素的水平居中,只要指定margin:0auto;即可

<pre> DIV#wrap{   width:760px;   margin:0auto;   border:1pxsolid#ccc;   background-color:#999;  }  pre> DIV> body> html>

[可先修改部分代码再运行查看效果]

上面的效果很好。但是这在InternetExplorer6及改正的版本中是不起作用的,不过幸好它有自己的解决办法。在InternetExplorer中text-align属性是可继承的,即在父元素中设置后在子元素中就默认具有了该属性。因此我们可以在body标签中设置text-align属性值为center,这样页面内所有的元素都会自动居中,同时我们还要加一个hook把页面中的文字变成我们习惯的阅读方式——居左对齐。因此我们要如此来写代码:

ExampleSourceCode

body{text-align:center;}  #wrap{text-align:left;}

这样在InternetExplorer中我们就轻松实现了DIV的居中对齐。因此要在所有的浏览器中显示居中的效果,我们就可以这样写我们的代码:

ExampleSourceCode

body{text-align:center;}  #wrap{text-align:left;  margin:0auto;  }

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <title>52CSS.comtitle> <metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=UTF-8"/> <styletypestyletype="text/css"> body{text-align:center;}  DIV#wrap{   text-align:left;   width:760px;   margin:0auto;   border:1pxsolid#333;   background-color:#ccc;  }  style> head>  <body> <DIVidDIVid="wrap">

在Firefox等现代浏览器设定页面元素的水平居中,只要指定margin:0auto;即可

<pre> DIV#wrap{   width:760px;   margin:0auto;   border:1pxsolid#ccc;   background-color:#999;  }

在InternetExplorer6及以下的版本中我们还要做以下的设置:

 body{text-align:center;}    DIV#wrap{   text-align:left;   }  pre> DIV> body> html>

[可先修改部分代码再运行查看效果]

不过这里有一个前提,就是设置居中的元素要有固定的宽度,比如这里我们设定了为760像素。

二、相对定位与负的边距

对于wrap进行相对定位,然后使用负的边距抵消偏移量。这种方法比较简单还很容易实现:

ExampleSourceCode

#wrap{  position:relative;  width:760px;  left:50%;  margin-left:-380px  }

这段代码的意思是,设置wrap的定位是相对于其父元素body标签的,然后将其左边框移动到页面的正中间(也就是left:50%含意);***我们再从中间位置向左偏移回一半的距离来,这样就实现了水平居中了。

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <title>52CSS.comtitle> <metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=UTF-8"/> <styletypestyletype="text/css"> DIV#wrap{   position:relative;   width:760px;   left:50%;   margin-left:-380px;   border:1pxsolid#333;   background-color:#ccc;  }  style> head>  <body> <DIVidDIVid="wrap">

在所有浏览器中都有效的方法:

<pre> DIV#wrap{   position:relative;   width:760px;   left:50%;   margin-left:-380px;   border:1pxsolid#333;   background-color:#ccc;  }  pre> DIV> body> html>

[可先修改部分代码再运行查看效果]
同样,在设定水平居中前你需要设定一个固定的宽度。

◆究竟选择哪个方法?

上面两个方法究竟选择哪种方法好呢?在***种方法中貌似使用了Hack技术,其实并没有,它是中规中矩的Web标准写法,完全符合规范,因此,两个种方法中完全可以随便的选取其中的任一种进行使用,他们不存在Csshack的问题。

三、其它的居中方式

上面所说的都是设定了具体宽度的情况下水平居中的实现。有时候我们想做一个弹性布局,或者当一个元素处于一个容器中时我们只想让它居中并不想设定一个具体的宽度。其实这并不是真正的居中布局,就像对一个100%长度的元素来说,你说它是居中对齐还是居左对齐呢?所以所有不高宽度的居中都不是真正的居中。这样的设计我们是使用的像元素的padding来设置的,实际中我们是改变了父元素的容器大小:
如我们希望wrap元素长度随窗口而改变,同时又维持居中,我们就可以这样写:

ExampleSourceCode

body{  padding:10px150px;  }

这里,我们只需要保持父元素左右两侧的填充是相等的就可以了。

SourceCodetoRun

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> <head> <title>52CSS.comtitle> <metahttp-equivmetahttp-equiv="Content-Type"content="text/html;charset=UTF-8"/> <styletypestyletype="text/css"> body{   padding:10px150px;  }  DIV#wrap{   border:1pxsolid#333;   background-color:#ccc;  }  style> head>  <body> <DIVidDIVid="wrap">

一种随浏览器窗口大小而改变的具有弹性的居中布局:

<pre> body{   padding:10px150px;  }   这里,我们只需要保持父元素左右两侧的填充是相等的就可以了。  pre> DIV> body> html>

到此,关于“CSS中怎么实现DIV容器水平居中”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: CSS中怎么实现DIV容器水平居中

本文链接: https://lsjlt.com/news/79470.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • CSS中怎么实现DIV容器水平居中
    这篇文章主要介绍“CSS中怎么实现DIV容器水平居中”,在日常操作中,相信很多人在CSS中怎么实现DIV容器水平居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS中怎么...
    99+
    2024-04-02
  • div内容水平居中与div内容垂直居中怎么实现
    这篇文章主要讲解了“div内容水平居中与div内容垂直居中怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“div内容水平居中与div内容垂直居中怎么实...
    99+
    2024-04-02
  • css实现div水平和垂直居中
    这篇文章主要介绍“css实现div水平和垂直居中”,在日常操作中,相信很多人在css实现div水平和垂直居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css实现div水平...
    99+
    2024-04-02
  • CSS怎么实现DIV文字水平左右居中
    本文小编为大家详细介绍“CSS怎么实现DIV文字水平左右居中”,内容详细,步骤清晰,细节处理妥当,希望这篇“CSS怎么实现DIV文字水平左右居中”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学...
    99+
    2024-04-02
  • 怎么用纯CSS实现div水平垂直居中
    这篇文章将为大家详细讲解有关怎么用纯CSS实现div水平垂直居中,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 要让一个DIV水平居中,只要设置可div的宽度高度就可以...
    99+
    2024-04-02
  • css怎么实现水平居中
    这篇文章主要介绍了css怎么实现水平居中的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css怎么实现水平居中文章都会有所收获,下面我们一起来看看吧。使用text-align属性实现行内元素水平居中页面布局:&l...
    99+
    2023-07-04
  • css3中flex怎么实现div内容水平垂直居中
    这篇文章给大家分享的是有关css3中flex怎么实现div内容水平垂直居中的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、flex-direction: (元素排列方向)※ flex-direction:row...
    99+
    2023-06-08
  • CSS中怎么实现DIV的图片水平垂直居中
    这篇文章主要介绍了CSS中怎么实现DIV的图片水平垂直居中的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS中怎么实现DIV的图片水平垂直居中文章都会有所收获,下面我们一起来...
    99+
    2024-04-02
  • CSS怎么实现单个div对象层水平居中
    今天小编给大家分享一下CSS怎么实现单个div对象层水平居中的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一...
    99+
    2024-04-02
  • css中如何让div水平居中
    小编给大家分享一下css中如何让div水平居中,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 要让div程度居中设置装备摆设m...
    99+
    2024-04-02
  • CSS中怎样实现水平居中
    这篇文章给大家介绍CSS中怎样实现水平居中,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。前面的话   水平居中是经常遇到的问题。看似方法较多,条条大路通罗马。但系统梳理下,其...
    99+
    2024-04-02
  • css怎样实现水平居中
    这篇文章主要介绍了css怎样实现水平居中,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。假设现在给出这种场景:<div cla...
    99+
    2024-04-02
  • 怎么用CSS将DIV水平居中对齐
    这篇文章将为大家详细讲解有关怎么用CSS将DIV水平居中对齐,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 答:使用CSSmargin属性 如果您想使<div&...
    99+
    2024-04-02
  • CSS怎么实现图片在div内垂直水平居中
    这篇“CSS怎么实现图片在div内垂直水平居中”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇...
    99+
    2024-04-02
  • div内容水平居中与div内容垂直居中的方法
    本文小编为大家详细介绍“div内容水平居中与div内容垂直居中的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“div内容水平居中与div内容垂直居中的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢...
    99+
    2024-04-02
  • css如何设置div水平居中
    这篇文章主要介绍“css如何设置div水平居中”,在日常操作中,相信很多人在css如何设置div水平居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css如何设置div水平...
    99+
    2024-04-02
  • CSS中怎么实现元素水平居中
    本篇文章为大家展示了CSS中怎么实现元素水平居中,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。CSS常见的让元素水平居中显示方法用CSS让元素居中显示并不是件很简单...
    99+
    2024-04-02
  • CSS中怎么实现水平、垂直居中
    这篇文章给大家介绍CSS中怎么实现水平、垂直居中,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。首先我先创建一个公共的模板样式<template>  <div class=...
    99+
    2023-06-08
  • HTML中怎么让div水平居中
    这篇文章主要介绍了HTML中怎么让div水平居中的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML中怎么让div水平居中文章都会有所收获,下面我们一起来看看吧。 运用ma...
    99+
    2024-04-02
  • CSS怎么实现​水平垂直居中
    这篇文章主要介绍“CSS怎么实现水平垂直居中”,在日常操作中,相信很多人在CSS怎么实现水平垂直居中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS怎么实现水平垂直居中”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-05
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作