实现HTML两栏布局

Flex 布局

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
.container {
  display: flex;
}

.left {
  width: 200px; /* 固定左边宽度 */
  background-color: lightblue;
}

.right {
  flex: 1; /* 右边占据剩余空间 */
  background-color: lightpink;
}
</style>
<body>
    <div class="container">
        <div class="left">左边内容</div>
        <div class="right">右边内容</div>
    </div>
</body>
</html>

浮动 + margin

复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>
  .container {
    overflow: hidden;
    /* 清除浮动 */
  }

  .left {
    float: left;
    width: 200px;
    background-color: lightblue;
  }

  .right {
    margin-left: 200px;
    /* 与左边元素的宽度相同 */
    background-color: lightpink;
  }
</style>

<body>
  <div class="container">
    <div class="left">左边内容</div>
    <div class="right">右边内容</div>
  </div>
</body>

</html>

Grid 布局

复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>
.container {
  display: grid;
  grid-template-columns: 200px 1fr;
}

.left {
  background-color: lightblue;
}

.right {
  background-color: lightpink;
}
</style>

<body>
  <div class="container">
    <div class="left">左边内容</div>
    <div class="right">右边内容</div>
  </div>
</body>

</html>

.container {

display: grid;

grid-template-columns: 200px 1fr;

}

1fr :表示第二列会占据剩余的所有空间。fr 是一个弹性单位,代表"分数",它会根据剩余空间的比例来分配宽度。

相关推荐
万少7 小时前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站10 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名12 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫12 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊12 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter12 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折13 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_13 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码113 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial13 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js