最新公告
  • 欢迎您光临凯崖之家,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入我们
  • 这篇文章主要介绍了HTML+CSS相对宽度和绝对宽度冲突时的div解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    相对宽度和绝对宽度冲突时的div解决方法

    摘要:一般我们在使用绝对宽度时会使用px,相对宽度时会使用%,但是要是同时使用绝对宽度和相对宽度时该怎么办呢?

    我们通过一道例题来讲解今天的内容:

    1.完成图片上的题目要求

    2.尝试提供这样一种方案,使得宽度与屏幕等宽,布局大体与1类似,并且保证你无论怎么调整浏览器的宽度,都可以保证中间部分布局相对宽度不变化,且格子间的间距均为10px

    题目1很简单,有许多种解决方案,我就不一一赘述了

    分析题目2,发现有两个关键的需求:

    相对宽度:格子的相对宽度(比例)不变

    绝对宽度:格子间的绝对距离不变

    如果只关注相对宽度,那么很简单,令左边格子的宽度为30%(举例),右边各自的宽度为70%即可;如果只关注绝对宽度,那么更简单,令中间的距离为10px即可。但是同时要满足时怎么办呢?难不成要写 width:(inherit-10px)*30% 么?

    显然不可以。我来讲讲我的解决方案吧(本人小白,如果有疏忽纰漏,或者您有更好的方案,欢迎在评论区指正!)

    先写出大体的盒子框架

    <!-- Tiger的代码世界 -->
    <!doctype html>
    <html>
    <head>
    <title>相对宽度和绝对宽度讨论</title>
    <meta charset="utf-8">
    <link rel="stylesheet" href="style.css">
    </head>
    <body>
    <div id="top">
    </div>
    <div class="wrapper">
    <div id="left">
    </div>
    <div id="right">
    </div>
    </div>
    <div id="bottom">
    </div>
    </body>
    </html>

     

    首先明确,相对宽度和绝对宽度的问题是不能同时解决的(1.就本题而言 2.欢迎指正)

    那我们就把问题拆分:先解决相对宽度,后解决绝对宽度or先解决绝对宽度,后解决相对宽度。就本题而言,前者更简便一些。而我们怎么“拆分”问题呢?——当然是容器div啦!

    我们先解决相对宽度:

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

    这就很简单了,左边宽度为30%,右边宽度为70%

    那怎么解决left容器里面的布局呢?

    我们先想一想:能不能做一个左边是宽度固定的格子,右边是宽度可变的格子的容器?当然可以,这不是就是导航栏么!这个简单得很,我随便找一种方法粘在下面了:

    #left{
    height: 300px;
    float: left;
    width: 150px;
    }
    #right{
    height: 300px;
    width: auto;
    margin-left: 150px;
    }

    这样问题是不是就马上解决了呢?

    所以下次遇到相对和绝对冲突的时候,一定要使用好div这把利器啊!

    当然我们也要注意一些小细节,比如如何处理border的问题等,这需要调一下外面容器和里边容器的高度(相差2*border-width),并且为了使right容器和左边相适应,right里面还要再套一个div才行。

    盒式模型是css布局的基本功,大家一定要对其有深刻的理解,才应用在各种变形上。完成这道题还需要对margin、padding(虽然这道题没有用到)、border以及div的关系有相当的理解,今天我就不再多讲了,下次有时间再说。

    下面把我的全部代码粘上,对大家一个参考,要是有更好的方案,一定要在留言区分享哦!

    HTML:

    <!Tiger的代码世界>
    <!doctype html>
    <html>
    <head>
    <title>CSS布局练习</title>
    <meta charset="utf-8">
    <link rel="stylesheet" href="style.css">
    </head>
    <body>
    <div id="top">
    </div>
    <div class="wrapper">
    <div id="left">
    <div class="innerright"></div>
    <div class="inner"></div>
    </div>
    <div id="right">
    <div class="inner"></div>
    </div>
    </div>
    <div id="bottom">
    </div>
    </body>
    </html>

    CSS:

     

    /*Tiger的代码世界*/
    /*题目中的宽度不明确是加border和margin的宽度还是不加border和margin的宽度
    以下皆默认为不加border和margin的宽度*/
    *{
    margin: 0px;
    padding: 0px;
    border-width: 3px;
    border-style: solid;
    border-color: black;
    }
    html{
    margin: 0;
    padding: 0;
    border-width: 0;
    width: 100%;
    }
    body{
    margin: 0;
    padding: 0;
    border-width: 0;
    }
    #top{
    margin: 10px;
    height: 150px;
    }
    .wrapper{
    margin: 10px;
    height: 300px;
    width: inherit;
    border-width: 0;
    }
    #left{
    height: 300px;
    width: 30%;
    float: left;
    border-width: 0;
    }
    #left .inner{
    height: 294px;
    width: auto;
    margin-right: 10px;
    }
    #left .innerright{
    height: 294px;
    width: 10px;
    float: right;
    border-width: 0;
    margin-left: 10px;
    }
    #right{
    height: 300px;
    width: 70%;
    float: right;
    border-width: 0;
    }
    #right .inner{
    height: 294px;
    width: auto;
    }
    #bottom{
    margin: 10px;
    height: 150px;
    }

    到此这篇关于HTML+CSS相对宽度和绝对宽度冲突时的div解决方法的文章就介绍到这了

    凯崖之家KAIYAZJ.COM一个优质的模板开发平台
    凯崖之家 » HTML+CSS相对宽度和绝对宽度冲突时的div解决方法

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    凯崖之家
    一个高级程序员模板开发平台

    发表评论

    发表评论

    • 252会员总数(位)
    • 1064资源总数(个)
    • 103本周发布(个)
    • 13 今日发布(个)
    • 297稳定运行(天)

    凯崖之家KAIYAZJ.COM一个优质的模板开发平台

    立即查看 立即注册
    升级SVIP尊享更多特权立即升级