如何让div大小随窗口大小变化 10

具体问题是这样的:我在一个页面里,想要设定一个大div,让其在页面中的高度随浏览器窗口的大小来自动改变(差不多就是说顶部触顶底部触底,div与页面高度间是固定差值,而不是... 具体问题是这样的:
我在一个页面里,想要设定一个大div,让其在页面中的高度随浏览器窗口的大小来自动改变(差不多就是说顶部触顶底部触底,div与页面高度间是固定差值,而不是百分百关系),其内部有多个div排列,并且中间有一个小div是随大DIV的高度变化的。
比如说下面大DIV中的五个div
假设页面高度为X
大DIV的高度就是"X-10"(不因为内部内容多而引起高度变形),并且上下padding各5。——<!-- 这个我觉得百分比无法精确实现-->
而大DIV中的1、2、3、5这几个小div高度为Y的话,让div4的高度随时都=“大DIV - 四个Y”的动态高度。
这个要怎么实现?必须jS么?

我只能到这一步就无语了:
<body style="color:#FFF"><div style="width:300px; margin:0 auto; height:auto">
<div style="height:30px; background-color:#199">第1个DIV</div> <div style="height:30px; background-color:#188">第2个DIV</div>
<div style="height:30px; background-color:#177">第3个DIV</div>
<div style="height:150px; background-color:#166">第4个DIV栏<br />这个要随网页高度动态变化高度</div>
<div style="height:30px; background-color:#155">第5个DIV栏</div>
</div></body>

-------------------------------
各位大侠帮帮忙~~~谢了~~~
展开
 我来答
弋橙ii
2017-06-05
知道答主
回答量:1
采纳率:0%
帮助的人:990
展开全部

大致讲一下思路。

1、设定一个最外层容器div-box,实现【顶部触顶底部触底,div与页面高度间固定差值】,在css文件中的.div-box下可修改margin数值)

2、前三个div可公用一个样式 div1

3、第五个div绝对定位在底部 div5,需要将div-box的position设为relative,否则会基于body定位。

4、第四个div设置高度为100% (如果样式需要设置高度撑满整个页面,那么最外层高度设置必须设置为100%),绝对定位到div-box中。

以下是代码。

html页面代码

<!DOCTYPE html>
<html>
<head>
<title>div大小随窗口大小变化</title>
<meta charset="utf-8">
<link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
<div class="div-box">
<div class="div1">div1固定高度</div>
<div class="div1">div2固定高度</div>
<div class="div1">div3固定高度</div>
<div class="div4">div4动态高度</div>
<div class="div5">div5固定高度</div>
</div>
</body>
</html>

css样式

html,body{
    height:100%;
    margin: 0;
    font-size: 24px;
    color: #fff;
    font-family: '微软雅黑';
    line-height: 50px;
    text-align: center;
}

.div-box{
    position: relative;
    width: 320px;
    height: 100%;
    margin: 20px 0; margin-left: 120px;
    background: #87CEFA;
    border: #ccc solid 5px;
}
.div1{
    border: #fff solid 1px;
    height: 50px;
}
.div4{
    position: absolute;
    width: 100%;
    border: #fff solid 1px;
    height: 100%;
}
.div5{
    position: absolute;
    border: #fff solid 1px;
    width: 100%;
    height: 50px;
    bottom: 0;
}
真_五花肉
推荐于2017-04-27
知道答主
回答量:2
采纳率:0%
帮助的人:3072
展开全部
给body加一个height:100%;给html加一个height:100%,然后需要根据页面高度变化的div的高度也写成百分比,试试看,但要精确实现你说的比窗口小10px好像不太好实现
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
唫铯娍寶
2016-10-28
知道答主
回答量:5
采纳率:0%
帮助的人:4266
展开全部
整个盒子这样写:
position: absolute;
left: 0;
top: 0;
width: 240px;
height: 100%;
background: red;

上下的距离可以用空DIV写
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
起个名字真烦d
2015-11-03
知道答主
回答量:1
采纳率:0%
帮助的人:1190
展开全部
给div的css加上position:absolute;这个属性。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
诶特顿
2013-01-11 · TA获得超过778个赞
知道小有建树答主
回答量:409
采纳率:75%
帮助的人:178万
展开全部
这样动态的变化除了百分比就剩下js能实现啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式