【HTML&&CSS】页面版块布局(亲身实践,帮你避坑)

简介: 【HTML&&CSS】页面版块布局(亲身实践,帮你避坑)

⭐⭐⭐🍔🍔🍔🏳️‍🌈🏳️‍🌈🏳️‍🌈

目录

⭐先说大招

案例1

编辑 原因:

案例2

法一:

法二:


⭐先说大招

16.1.png

案例1

平时学的时候没有在意这一点,感觉很简单,但是真正实践的时候就傻眼了🤐

先来一个题目

盒子尺寸300*300,背景天蓝色,边框10px实线黄绿色,上下左右20px的内边距,水平居中

错误代码

错误代码

错误代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    div{
      width: 300px;
      height: 300px;
      background-color: skyblue;
      border: 10px solid greenyellow;
      padding: 20px;
    }
  </style>
</head>
<body>
  <div></div>
</body>
</html>

结果

image.png

右击检查,发现盒子大小已经超出300px了

16.2.png

原因:

⭐border会撑大盒子


⭐padding会撑大盒子


解决方法


那么为了实现需求,可以改变盒子的实际宽度


(实际大小=左border+左padding+内容宽度+右padding+右border)


那么变成width: 240px即可


🚥🚥🚥🚥🚥🚥


案例2

下面我将用两种方法来实现下图的布局  

image.png

法一:

使用浮动

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }
    .box{
      margin: 0 auto;
      position: relative;
      width: 800px;
      height: 794px;
      border: 1px solid black;
    }
    .header{
      margin: 0 auto;
      height: 198px;
      width: 790px;
      margin-top: 4px;
      margin-bottom: 4px;
      border: 1px solid black;
    }
    .leftside {
      float: left;
      height: 498px;
      width: 292px;
      margin-left: 4px;
      margin-right: 4px;
      border: 1px solid black;
    }
    .rightside{
      float: right;/*一定得是右浮动,不是左浮动*/
      margin-right: 4px;
      height: 498px;
      width: 492px;
      border: 1px solid black;
    }
    .footer{
      position: absolute;/*这样子把footer盒子固定在大盒子底部*/
      margin-top: 4px;
      margin: 0 auto;
      margin-left: 4px;
      bottom: 4px;
      height: 76px;
      width: 790px;
      border: 1px solid black;
    }
  </style>
</head>
<body>
  <div class="box">
    <div class="header">header</div>
    <div class="leftside">leftside</div>
    <div class="rightside">rightside</div>
    <div class="footer">footer</div>
  </div>
</body>
</html>

法二:

使用位置定位

父相子绝(父亲属性是:relative,儿子属性是:absolate)

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .box {
      margin: 0 auto;
      position: relative;/*父相子绝*/
      width: 800px;
      height:794px ;
      border: 1px solid;
    }
    .header {
      margin: 4px;
      border: 1px solid;
      width: 790px;
      height: 198px;
    }
    .leftside {
      position: absolute;/*父相子绝*/
      left: 4px;          /*离父盒子左边距的距离*/
      bottom: 86px;       /*离父盒子下边距的距离*/
      border: 1px solid;
      width: 292px;
      height: 498px;
    }
    .rightside {
      position: absolute;/*父相子绝*/
      left: 302px;
      right: 4px;
      bottom: 86px;
      width: 492px;
      height: 498px;
      border: 1px solid;
    }
    .footer {
      position: absolute;/*父相子绝*/
      margin-left:4px ;
      margin-right: 4px;
      bottom: 4px;
      width: 790px;
      height: 76px;
      border: 1px solid;
    }
  </style>
</head>
<body>
  <div class="box">
    <div class="header">header</div>
    <div class="leftside">leftside</div>
    <div class="rightside">rightside</div>
    <div class="footer">footer</div>
  </div>
</body>
</html>

Code over!

相关文章
|
13天前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
26 6
|
1月前
|
移动开发 前端开发 JavaScript
[HTML、CSS]细节与使用经验
本文总结了前端开发中的一些重要细节和技巧,包括CSS选择器、定位、层级、全局属性、滚轮控制、轮播等。作者以纯文字形式记录,便于读者使用<kbd>Ctrl + F</kbd>快速查找相关内容。文章还提供了示例代码,帮助读者更好地理解和应用这些知识点。
42 1
[HTML、CSS]细节与使用经验
|
1月前
|
移动开发 前端开发 JavaScript
[HTML、CSS]知识点
本文涵盖前端知识点扩展、HTML标签(如video、input、canvas)、datalist和details标签的使用方法,以及CSS布局技巧(如margin、overflow: hidden和动态height)。文章旨在分享作者的学习经验和实用技巧。
33 1
[HTML、CSS]知识点
|
27天前
|
移动开发 JavaScript 前端开发
html table+css实现可编辑表格的示例代码
html table+css实现可编辑表格的示例代码
49 12
|
27天前
html页面点击按钮实现页面跳转功能
html页面点击按钮实现页面跳转
50 11
|
27天前
|
容器
HTML中使用Flex布局实现双行夹批效果
在HTML中,还可以用table元素来实现双行夹批效果,但比flex布局代码更复杂,效果也不见得更理想。
39 10
|
23天前
|
前端开发 JavaScript
用HTML CSS JS打造企业级官网 —— 源码直接可用
必看!用HTML+CSS+JS打造企业级官网-源码直接可用,文章代码仅用于学习,禁止用于商业
102 1
|
28天前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
41 3
|
20天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
34 0