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

这篇文章主要介绍了HTML+CSS相对宽度和绝对宽度冲突时的div解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

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

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

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

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

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

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

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

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

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

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

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

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

先写出大体的盒子框架


相对宽度和绝对宽度讨论

top和bottom容器我就不赘述了。我只讲中间部分。

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

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

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

我们先解决相对宽度:

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

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

这就很简单了,左边宽度为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:

CSS布局练习

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解决方法的文章就介绍到这了,更多相关HTML+CSS相对宽度和绝对宽度冲突内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

来源:脚本之家

链接:https://www.jb51.net/web/732930.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:SEO优化专员,转转请注明出处:https://www.chuangxiangniao.com/p/899644.html

(0)
上一篇 2025年1月4日 01:40:28
下一篇 2025年1月4日 01:40:49

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解css3 flex弹性盒自动铺满写法

    这篇文章主要介绍了详解css3 flex弹性盒自动铺满写法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。 本文主要介绍了详解css3 flex弹性盒自动铺满写法,分享…

    服务器 2025年1月4日
    300
  • CSS中三角形的绘制与巧妙应用实例详解

    这篇文章主要介绍了CSS中三角形的绘制与巧妙应用,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下 引 网页中常见的一些三角形,无需制作成图片或者字体图标,使用CSS就可以直接画出来。如小…

    2025年1月4日 服务器
    100
  • 详解CSS-opacity子元素继承父元素透明度的解决方法

    这篇文章主要介绍了详解CSS-opacity子元素继承父元素透明度的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 在写项目页面的过程中,遇到子元素继承父元素透…

    服务器 2025年1月4日
    100
  • HTML+CSS+JS实现堆叠轮播效果的示例代码

    这篇文章主要介绍了HTML+CSS+JS实现堆叠轮播效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下 效果: 轮播图在向一个方向移动的同时,要对其每一个图片的大小,位置,透明度以及层…

    服务器 2025年1月4日
    100
  • css解决浮动导致父元素高度坍塌的几种方法

    这篇文章主要介绍了css解决浮动导致父元素高度坍塌的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 一、文档流与浮动 1、’什么是文档流? 在html中,文档流…

    2025年1月4日 服务器
    100
  • css下div下同行多元素右对齐

    这篇文章主要介绍了css下div下同行多元素右对齐,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 方法一: float:right 此外,浮动还会使得布局更紧凑(没空隙…

    2025年1月4日
    100
  • css实现元素垂直居中显示的7种方式

    这篇文章主要介绍了css实现元素垂直居中显示的7种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 【一】知道居中元素的宽高 absolute + 负margin 代…

    2025年1月4日 服务器
    100
  • 纯css实现流向性和动态线条效果的代码

    这篇文章主要介绍了纯css实现流向性和动态线条效果的代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或功能具有一定的参考借鉴价值,需要的朋友可以参考下 思路: 一个外层盒子设置背景;一个内层盒子设置宽高背景,并设置animate让盒…

    服务器 2025年1月4日
    100
  • 详解CSS 子元素相对于父元素固定定位解决方案

    这篇文章主要介绍了详解CSS 子元素相对于父元素固定定位解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 基本概念 绝对定位(absolute):设置为绝对定位的…

    服务器 2025年1月4日
    100
  • CSS实现子元素div水平垂直居中的示例

    这篇文章主要介绍了CSS实现子元素div水平垂直居中的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 div基本布局 css样式 1. 配合定位与margin:au…

    服务器 2025年1月4日
    100

发表回复

登录后才能评论

联系我们

156-6553-5169

在线咨询: QQ交谈

邮件:253000106@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

联系微信