[前端] HTML+CSS相对宽度和绝对宽度冲突时的div解决方法

1851 0
黑夜隐士 2022-10-19 15:50:41 | 显示全部楼层 |阅读模式
相对宽度和绝对宽度冲突时的div解决方法
摘要:一般我们在使用绝对宽度时会使用px,相对宽度时会使用%,但是要是同时使用绝对宽度和相对宽度时该怎么办呢?
我们通过一道例题来讲解今天的内容:


1.完成图片上的题目要求
2.尝试提供这样一种方案,使得宽度与屏幕等宽,布局大体与1类似,并且保证你无论怎么调整浏览器的宽度,都可以保证中间部分布局相对宽度不变化,且格子间的间距均为10px
题目1很简单,有许多种解决方案,我就不一一赘述了
分析题目2,发现有两个关键的需求:
相对宽度:格子的相对宽度(比例)不变
绝对宽度:格子间的绝对距离不变
如果只关注相对宽度,那么很简单,令左边格子的宽度为30%(举例),右边各自的宽度为70%即可;如果只关注绝对宽度,那么更简单,令中间的距离为10px即可。但是同时要满足时怎么办呢?难不成要写 width:(inherit-10px)*30% 么?
显然不可以。我来讲讲我的解决方案吧(本人小白,如果有疏忽纰漏,或者您有更好的方案,欢迎在评论区指正!)
先写出大体的盒子框架
  1. <!-- Tiger的代码世界 -->
  2. <!doctype html>
  3. <html>
  4. <head>
  5.     <title>相对宽度和绝对宽度讨论</title>
  6.     <meta charset="utf-8">
  7.     <link rel="stylesheet" href="style.css">
  8. </head>
  9. <body>
  10.     <div id="top">
  11.     </div>
  12.     <div class="wrapper">
  13.         <div id="left">
  14.         </div>
  15.         <div id="right">
  16.         </div>
  17.     </div>
  18.     <div id="bottom">
  19.     </div>
  20. </body>
  21. </html>
复制代码
top和bottom容器我就不赘述了。我只讲中间部分。


首先明确,相对宽度和绝对宽度的问题是不能同时解决的(1.就本题而言 2.欢迎指正)
那我们就把问题拆分:先解决相对宽度,后解决绝对宽度or先解决绝对宽度,后解决相对宽度。就本题而言,前者更简便一些。而我们怎么“拆分”问题呢?——当然是容器div啦!

我们先解决相对宽度:
我们让A和C合并,然后和B用相对宽度描述


这就很简单了,左边宽度为30%,右边宽度为70%
那怎么解决left容器里面的布局呢?
我们先想一想:能不能做一个左边是宽度固定的格子,右边是宽度可变的格子的容器?当然可以,这不是就是导航栏么!这个简单得很,我随便找一种方法粘在下面了:
  1. #left{
  2.     height: 300px;
  3.     float: left;
  4.     width: 150px;
  5. }
  6. #right{
  7.     height: 300px;
  8.     width: auto;
  9.     margin-left: 150px;
  10. }
复制代码
这样问题是不是就马上解决了呢?
所以下次遇到相对和绝对冲突的时候,一定要使用好div这把利器啊!
当然我们也要注意一些小细节,比如如何处理border的问题等,这需要调一下外面容器和里边容器的高度(相差2*border-width),并且为了使right容器和左边相适应,right里面还要再套一个div才行。
盒式模型是css布局的基本功,大家一定要对其有深刻的理解,才应用在各种变形上。完成这道题还需要对margin、padding(虽然这道题没有用到)、border以及div的关系有相当的理解,今天我就不再多讲了,下次有时间再说。
下面把我的全部代码粘上,对大家一个参考,要是有更好的方案,一定要在留言区分享哦!
HTML:
  1. <!Tiger的代码世界>
  2. <!doctype html>
  3. <html>
  4. <head>
  5.     <title>CSS布局练习</title>
  6.     <meta charset="utf-8">
  7.     <link rel="stylesheet" href="style.css">
  8. </head>
  9. <body>
  10.     <div id="top">
  11.     </div>
  12.     <div class="wrapper">
  13.         <div id="left">
  14.             <div class="innerright"></div>
  15.             <div class="inner"></div>
  16.         </div>
  17.         <div id="right">
  18.             <div class="inner"></div>
  19.         </div>
  20.     </div>
  21.     <div id="bottom">
  22.     </div>
  23. </body>
  24. </html>
复制代码
CSS:
  1. /*Tiger的代码世界*/
  2. /*题目中的宽度不明确是加border和margin的宽度还是不加border和margin的宽度
  3.   以下皆默认为不加border和margin的宽度*/
  4. *{
  5.     margin: 0px;
  6.     padding: 0px;
  7.     border-width: 3px;
  8.     border-style: solid;
  9.     border-color: black;
  10. }
  11. html{
  12.     margin: 0;
  13.     padding: 0;
  14.     border-width: 0;
  15.     width: 100%;
  16. }
  17. body{
  18.     margin: 0;
  19.     padding: 0;
  20.     border-width: 0;
  21. }
  22. #top{
  23.     margin: 10px;
  24.     height: 150px;
  25. }
  26. .wrapper{
  27.     margin: 10px;
  28.     height: 300px;
  29.     width: inherit;
  30.     border-width: 0;
  31. }
  32. #left{
  33.     height: 300px;
  34.     width: 30%;
  35.     float: left;
  36.     border-width: 0;
  37. }
  38. #left .inner{
  39.     height: 294px;
  40.     width: auto;
  41.     margin-right: 10px;
  42. }
  43. #left .innerright{
  44.     height: 294px;
  45.     width: 10px;
  46.     float: right;
  47.     border-width: 0;
  48.     margin-left: 10px;
  49. }
  50. #right{
  51.     height: 300px;
  52.     width: 70%;
  53.     float: right;
  54.     border-width: 0;
  55. }
  56. #right .inner{
  57.     height: 294px;
  58.     width: auto;
  59. }
  60. #bottom{
  61.     margin: 10px;
  62.     height: 150px;
  63. }
复制代码
到此这篇关于HTML+CSS相对宽度和绝对宽度冲突时的div解决方法的文章就介绍到这了,更多相关HTML+CSS相对宽度和绝对宽度冲突内容请搜索中国红客联盟以前的文章或继续浏览下面的相关文章,希望大家以后多多支持中国红客联盟!

本帖子中包含更多资源

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

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

本版积分规则

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行