【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!

相关文章
|
5天前
|
XML 前端开发 JavaScript
Html:CSS介绍
Html:CSS介绍
18 1
|
5天前
|
前端开发
Html:CSS的书写位置
Html:CSS的书写位置
14 0
|
1天前
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML与CSS之旅
【9月更文挑战第31天】在这个数字时代,拥有一个个人博客网站是展示自我、分享知识和连接世界的重要方式。本文将引导你通过简单的HTML和CSS知识,一步步构建起你的在线空间。无论你是编程新手还是希望通过实践加深理解,这篇文章都将是你的理想指南。我们将探索基本概念,实现页面布局,并点缀以个性化样式,最终将静态页面转变为动态交互式网站。准备好了吗?让我们开始吧!
|
5天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
18 6
|
5天前
|
XML 前端开发 JavaScript
jQuery HTML / CSS 方法
jQuery HTML / CSS 方法
8 2
|
7天前
|
JavaScript 前端开发
JavaScript HTML DOM - 改变CSS
JavaScript HTML DOM - 改变CSS
15 4
|
4天前
|
前端开发 JavaScript
HTML+JavaScript+CSS DIY 分隔条splitter
HTML+JavaScript+CSS DIY 分隔条splitter
|
5天前
|
前端开发 数据安全/隐私保护 容器
HTML+CSS 水滴登录页
该代码实现了一个创意的水滴登录页面,包含一个水滴形状的登录框与两个按钮(忘记密码和注册)。登录框包括用户名、密码输入框及登录按钮。页面设计独特,采用渐变色与动态效果,增强了交互性和视觉美感。以下为关键实现步骤: - 重置默认样式。 - 设置页面背景颜色和尺寸。 - 定义登录表单容器的布局、位置和尺寸。 - 设置登录表单内容样式,包括3D效果和过渡动画。 - 创建伪元素增强水滴效果。 - 设定输入框容器和输入框样式。 - 为提交按钮、忘记密码和注册按钮设定特定样式,并添加悬停效果。
|
6天前
|
前端开发 容器
css布局-弹性布局学习笔记
这篇文章是关于CSS弹性布局的学习笔记,详细介绍了flex容器和元素的相关属性,包括flex-direction、flex-wrap、flex-flow、justify-content、align-items、align-content以及order、flex-grow、flex-shrink、flex-basis、flex和align-self等,解释了这些属性在弹性盒子布局中的作用和用法。
|
6天前
|
JavaScript 前端开发
网页前端课程设计-【模仿】香港中文大学官网,轮播图及div+css布局,js的dom操作
这篇文章介绍了如何模仿香港中文大学官网进行网页前端课程设计,包括使用div+css布局、js的DOM操作以及实现轮播图等技术细节。