鱼C论坛

 找回密码
 立即注册
查看: 3163|回复: 3

[已解决]给body父级加相对位置反而实现不了垂直居中,为什么

[复制链接]
发表于 2018-4-29 15:47:31 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 不二如是 于 2018-4-29 15:56 编辑
  1. <!doctype html>
  2. <html>
  3.         <head>
  4.                 <meta charset="utf-8"/>
  5.                 <style type="text/css">
  6.                         html{
  7.                                 height: 100%;
  8.                         }
  9.                         body{
  10.                                 background: url(img/162464.jpg) center center;
  11.                                 background-size: cover;
  12.                                 margin: 0;
  13.                                 padding: 0;
  14.                                 position: relative;
  15.                         }
  16.                         #container{
  17.                                 position: absolute;
  18.                                 top: 50%;
  19.                                 width: 100%;
  20.                                 text-align: center;
  21.                                 transform: translateY(-50%);
  22.                         }
  23.                 </style>
  24.                
  25.         </head>
  26.         <body>
  27.                 <div id="container">
  28.                         <h1 style="font-family:'微软雅黑';">我爱鱼C</h1>
  29.                         <p>bbs.fishC.com - 编码改变生活</p>
  30.                         <p><a href="http://bbs.fishc.com">传送门</a></p>
  31.                 </div>
  32.         </body>
  33. </html>
复制代码

**************************************************************
如果把body里的position:relative注释掉就能实现垂直居中了,不二如是老师的代码里是要求加上去的才能实现
最佳答案
2018-4-29 16:52:11
本帖最后由 不二如是 于 2018-4-29 17:04 编辑
华丽转身123 发表于 2018-4-29 16:03
我是疑问为什么我加了反而实现不了垂直居中,你们加了都行,我为什么就不行呢


style一开始:
html,body{
                                height: 100%;
                        }

body没有高度,无法“撑开”,垂直布局
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-29 15:58:38 | 显示全部楼层
本帖最后由 不二如是 于 2018-4-29 16:00 编辑

父级relative,子集absolute,是一种定位技巧。

absolute定位后会脱离文档流(body),这样易于布局。

而此时如果它的父级是relative,那么虽然脱离文档流,但是都是相对于父级来进行定位。

去掉父级relative,为什么仍旧可以呢?

因为此时恰巧父级就是body,所以脱离文档流后仍旧是相对body进行定位。

假如有多个div嵌套,利用上面的定位,删掉后就无法实现哦~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-29 16:03:44 | 显示全部楼层
不二如是 发表于 2018-4-29 15:58
父级relative,子集absolute,是一种定位技巧。

absolute定位后会脱离文档流(body),这样易于布局。

我是疑问为什么我加了反而实现不了垂直居中,你们加了都行,我为什么就不行呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-29 16:52:11 | 显示全部楼层    本楼为最佳答案   
本帖最后由 不二如是 于 2018-4-29 17:04 编辑
华丽转身123 发表于 2018-4-29 16:03
我是疑问为什么我加了反而实现不了垂直居中,你们加了都行,我为什么就不行呢


style一开始:
html,body{
                                height: 100%;
                        }

body没有高度,无法“撑开”,垂直布局
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-20 13:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表