浏览器窗口大小变化时css的变化

最近做一个项目,发现了点问题,贴出来分析分析

做一个页面,页面布局需要根据屏幕大小的变化而变化。代码大致如下

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta http-equiv="expires" content="0">
<title>页面自适应</title>
<style type="text/css">
#main{min-width:940px;width:100%;height:505px;border:1px solid red;}
#left{width:200px;height:500px;border:1px solid blue;float:left;}
#right{min-width:730px;width:100%;height:500px;border:1px solid green;float:left;}
</style>
</head>

<body>
<div id="main">
<div id="left"> </div>
<div id="right"> </div>
<script type="text/javascript">
//document.getElementById("main").style.width = document.body.offsetWidth;
document.getElementById("right").style.width = document.getElementById("main").offsetWidth - 206 + "px";
</script>
</div>
</body>
</html>

设定了最小宽度,保证在窗口大小变化时页面不至于严重变形。在div中设定width的百分比,是以body为参照的。但是设定height的百分比,它就不那么听话了,解决办法是同时在css中设定html和body的height。
为了在左边div宽度固定时右边div能根据屏幕大小变化而变化,用了js来控制,如上面代码所示。
但是当浏览器窗口变小时,右边的div就跑到下面了。估计就是id为main的div宽度不够所致,在火狐下用Firebug看也没发现什么。后来在js中加上

document.getElementById("main").style.width = document.body.offsetWidth;

就一切正常了。
然后就开始想到底是怎么回事。js只会在页面刷新时运行,窗口大小变化时只有css起作用了。注掉添加的那句js,分别去掉main和right的min-width,在火狐下仍然看不出什么,在IE8下,去掉main的min-width发现main的宽度变小了,去掉right的min-width后right的宽度不发生变化。个人认为在窗口大小变化的时候,如果设定了min-width就会以变化之前的width和css中已设定min-width中较大者作为它的值。

以上纯属个人观点,不当之处还望口下留情并给予指正。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的登录页面,可以根据浏览器窗口的大小自适应布局。 HTML代码: ``` <!DOCTYPE html> <html> <head> <title>Login Page</title> <link rel="stylesheet" type="text/css" href="style.css"> </head> <body> <div class="container"> <h1>Login</h1> <form> <label for="username">Username:</label> <input type="text" id="username"> <label for="password">Password:</label> <input type="password" id="password"> <button type="submit">Login</button> </form> </div> </body> </html> ``` CSS代码: ``` body { margin: 0; padding: 0; background-color: #f2f2f2; font-family: Arial, sans-serif; } .container { width: 50%; margin: 0 auto; background-color: #fff; padding: 30px; border-radius: 10px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.3); } h1 { font-size: 2em; text-align: center; margin-bottom: 20px; } form { display: flex; flex-direction: column; align-items: center; } label { font-size: 1.2em; margin-bottom: 10px; } input { padding: 10px; margin-bottom: 20px; border-radius: 5px; border: none; box-shadow: 0 0 5px rgba(0, 0, 0, 0.1); width: 100%; } button { padding: 10px 20px; background-color: #4CAF50; color: #fff; border: none; border-radius: 5px; cursor: pointer; transition: background-color 0.3s ease; } button:hover { background-color: #3e8e41; } @media (max-width: 768px) { .container { width: 80%; } } ``` 在上面的代码中,我们使用了一个名为.container的div来包含整个登录表单。这个div具有50%的宽度和自动居中对齐,因此它会在浏览器窗口大小变化自适应布局。此外,我们还使用了一个媒体查询来在窗口宽度小于768px缩小.container的宽度到80%。 除此之外,我们还使用了flexbox布局来使表单元素水平居中对齐,并使用了一些CSS样式来美化表单元素的样式。 上面的代码只是一个简单的示例,您可以根据自己的需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值