CSS前端:元素的布局技巧

【备注】在线测试网站,点此进入

一、内边距和外边距

【总结】padding增加本元素和子元素的距离,margin增加本元素和父元素的距离。

二、居中和对齐

【需求】

【HTML】

html 复制代码
<div id="container">
    <p id="top">我在div容器的顶部</p>
    <div id="inner-container">
      <p id="left">我在div容器的最左边</p>
      <p id="center">我在div容器的最中心</p>
      <p id="right">我在div容器的最右边</p>
    </div>
    <p id="bottom">我在div容器的底部</p>
  </div>

【CSS实现一】绝对位置:top和left

css 复制代码
 #container {
    width: 600px;
    height: 300px;
    background-color: yellow;
    margin: 0 auto;//整个元素在页面中居中
  }

  #container p {
    position: absolute; /* 绝对定位 */
  }

  #top {
    top: 0; /* 顶部定位 */
    left: 50%; /* 居中 */
    transform: translateX(-50%); /* 水平居中 */
  }

  #left {
    top: 50%; /* 垂直居中 */
    left: 0; /* 左边 */
    transform: translate(100%, -100%); /* 垂直居中 */
  }

  #center {
    top: 50%; /* 垂直居中 */
    left: 50%; /* 水平居中 */
    transform: translate(-50%, -100%); /* 居中 */
  }

  #right {
    top: 50%; /* 垂直居中 */
    right: 0; /* 右边 */
    transform: translate(-100%, -100%); /* 垂直居中 */
  }

  #bottom {
    bottom: 0; /* 底部定位 */
    left: 50%; /* 居中 */
    transform: translate(-50%, -100%); /* 水平居中 */
  }

备注:

1.需要微调一下距离

2.居中语法:

css 复制代码
margin: 0 auto

【CSS实现二】Flex布局:指定排列方式

HTML要改,最中间三个元素要一起打包:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Flexbox布局示例</title>
  <link rel="stylesheet" href="styles.css">
</head>
<body>
  <div id="container">
    <p id="top">我在div容器的顶部</p>
    <div id="inner-container">
      <p id="left">我在div容器的最左边</p>
      <p id="center">我在div容器的最中心</p>
      <p id="right">我在div容器的最右边</p>
    </div>
    <p id="bottom">我在div容器的底部</p>
  </div>
</body>
</html>

CSS:

css 复制代码
#container {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 600px;
  height: 300px;
  background-color: yellow;
  margin: 0 auto;
  padding: 10px;
}

#inner-container {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

#top {
  margin-top: 0;
}

#left {
  margin-left: 0;
}

#right {
  margin-right: 0;
}

#bottom {
  margin-bottom: 0;
}

备注,这里设置了padding所以有点出入,设置为0即可

三、元素的覆盖

【需求】

【HTML】

html 复制代码
<div id="container">
  <div id="reddiv"></div>
  <div id="bluediv"></div>
</div>

【实现】

css 复制代码
#container {
  position: relative;
  width: 200px;
  height: 200px;
  background-color: yellow;
}

#reddiv, #bluediv {
  position: absolute;
  width: 200px;
  height: 200px;
}

#reddiv {
  background-color: red;
  z-index: 1; /* 红色div位于上层 */
  top: 100px;
  left: 0px;
}

#bluediv {
  background-color: blue;
  z-index: 2; /* 蓝色div位于更上层 */
  top: 100px;
  left: 100px;
}

举例下面的例子,指的是reddiv距离父级元素顶部100距离,叠放排序是1(越大越靠上)

css 复制代码
#reddiv {
  background-color: red;
  z-index: 1; /* 红色div位于上层 */
  top: 100px;
  left: 0px;
}
相关推荐
科技探秘人4 分钟前
Chrome与火狐哪个浏览器的隐私追踪功能更好
前端·chrome
科技探秘人4 分钟前
Chrome与傲游浏览器性能与功能的深度对比
前端·chrome
JerryXZR10 分钟前
前端开发中ES6的技术细节二
前端·javascript·es6
七星静香12 分钟前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
q24985969314 分钟前
前端预览word、excel、ppt
前端·word·excel
小华同学ai20 分钟前
wflow-web:开源啦 ,高仿钉钉、飞书、企业微信的审批流程设计器,轻松打造属于你的工作流设计器
前端·钉钉·飞书
Gavin_91529 分钟前
【JavaScript】模块化开发
前端·javascript·vue.js
懒大王爱吃狼2 小时前
Python教程:python枚举类定义和使用
开发语言·前端·javascript·python·python基础·python编程·python书籍
逐·風6 小时前
unity关于自定义渲染、内存管理、性能调优、复杂物理模拟、并行计算以及插件开发
前端·unity·c#
Devil枫6 小时前
Vue 3 单元测试与E2E测试
前端·vue.js·单元测试