css实现div水平、垂直居中兼容chrome、ie8
建站知识 2021-07-03 08:15www.168986.cn长沙网站建设
示例1 chrome33、ie8测试通过
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
/ 固定宽高div,在浏览器中保持水平、垂直居中 /
#div1 {
width:400px; height:300px;
position:absolute;
left:50%; :50%;
margin-left:-200px; margin-:-150px;
background:#f90;
}
</style>
</head>
<body>
<div id="div1"></div>
</body>
</html>
示例2 chrome33、ie8测试通过
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
/ 固定宽高div在固定宽高div中保持水平、垂直居中 /
#div1 {
width: 400px;height: 200px;
background-color: #f00;
position: relative;
/ 为div赋予单元格属性,使其可以应用align属性 /
display: table-cell;
vertical-align: middle;
}
#div2 {
width: 200px;height: 100px;
background-color: #0f0;
/ 使当前标签在父标签中水平居中,即0 auto 0 auto /
margin: 0 auto;
display: block;
}
</style>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
示例3 chrome33、ie8测试通过
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
{
margin: 0;
padding: 0;
box-sizing: border-box;
}
#div1 {
width: 400px;height: 200px;
background-color: #f00;
/ 使当前标签在父标签位置固定 /
position: absolute;
: 50%;left: 50%;
margin: -100px 0 0 -200px;
}
#div2 {
width: 200px;height: 100px;
background-color: #0f0;
display: block;
/ 使当前标签在父标签中保持水平、垂直居中 /
: 50%;left: 50%;
margin: 50px 0 0 100px;
}
</style>
</head>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
示例4 chrome33测试通过,ie8测试不通过,参考http://.w3school../tiy/t.asp?f=css3_box-pack
<!DOCTYPE html>
<html>
<head>
<style>
{
margin: 0;
padding: 0;
box-sizing: border-box;
}
/ 使用box-pack样式实现div中子元素居中 /
#div1 {
width:350px;
height:200px;
border:1px solid black;
/ Firefox /
display:-moz-box;
-moz-box-pack:center;
-moz-box-align:center;
/ Safari, Chrome, and Opera /
display:-webkit-box;
-webkit-box-pack:center;
-webkit-box-align:center;
/ W3C /
display:box;
box-pack:center;
box-align:center;
}
#div2 {
width:100px;
height:50px;
background-color: #ff0;
border:1px solid black;
}
</style>
</head>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
注对页面中所有元素应用box-sizing:border-box样式是为了将padding、margin值都计入width、height中,即为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制(http://.w3school../cssref/pr_box-sizing.asp)。在上述代码中应用该样式无意义,在企业级应用中应用该样式可以减少很多界面缺陷,如标签未对齐。
复制代码
代码如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
/ 固定宽高div,在浏览器中保持水平、垂直居中 /
#div1 {
width:400px; height:300px;
position:absolute;
left:50%; :50%;
margin-left:-200px; margin-:-150px;
background:#f90;
}
</style>
</head>
<body>
<div id="div1"></div>
</body>
</html>
示例2 chrome33、ie8测试通过
复制代码
代码如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
/ 固定宽高div在固定宽高div中保持水平、垂直居中 /
#div1 {
width: 400px;height: 200px;
background-color: #f00;
position: relative;
/ 为div赋予单元格属性,使其可以应用align属性 /
display: table-cell;
vertical-align: middle;
}
#div2 {
width: 200px;height: 100px;
background-color: #0f0;
/ 使当前标签在父标签中水平居中,即0 auto 0 auto /
margin: 0 auto;
display: block;
}
</style>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
示例3 chrome33、ie8测试通过
复制代码
代码如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
{
margin: 0;
padding: 0;
box-sizing: border-box;
}
#div1 {
width: 400px;height: 200px;
background-color: #f00;
/ 使当前标签在父标签位置固定 /
position: absolute;
: 50%;left: 50%;
margin: -100px 0 0 -200px;
}
#div2 {
width: 200px;height: 100px;
background-color: #0f0;
display: block;
/ 使当前标签在父标签中保持水平、垂直居中 /
: 50%;left: 50%;
margin: 50px 0 0 100px;
}
</style>
</head>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
示例4 chrome33测试通过,ie8测试不通过,参考http://.w3school../tiy/t.asp?f=css3_box-pack
复制代码
代码如下:<!DOCTYPE html>
<html>
<head>
<style>
{
margin: 0;
padding: 0;
box-sizing: border-box;
}
/ 使用box-pack样式实现div中子元素居中 /
#div1 {
width:350px;
height:200px;
border:1px solid black;
/ Firefox /
display:-moz-box;
-moz-box-pack:center;
-moz-box-align:center;
/ Safari, Chrome, and Opera /
display:-webkit-box;
-webkit-box-pack:center;
-webkit-box-align:center;
/ W3C /
display:box;
box-pack:center;
box-align:center;
}
#div2 {
width:100px;
height:50px;
background-color: #ff0;
border:1px solid black;
}
</style>
</head>
<body>
<div id="div1">
<div id="div2"></div>
</div>
</body>
</html>
注对页面中所有元素应用box-sizing:border-box样式是为了将padding、margin值都计入width、height中,即为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制(http://.w3school../cssref/pr_box-sizing.asp)。在上述代码中应用该样式无意义,在企业级应用中应用该样式可以减少很多界面缺陷,如标签未对齐。
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键