Skip to content

css布局

概要

提示:提供一些常见布局

目前,Flexbox 是一种非常常见的 CSS 布局方式,但很多人在学习和使用时并未真正掌握它的核心思想。在编写 CSS 时,为什么要固定元素的宽高呢?这是一个误区,因为你无法预料某个元素的内容未来会有多高。此外,固定宽高会导致内容在不同设备上出现不适配的问题,尤其是在屏幕大小变化时,内容容易被挤压、换行。例如,设计稿在 1080 像素的屏幕上一行显示的内容,到了 750 像素的设备上就可能换行。

通过深入学习,我发现 flex-basis 是一个非常实用的属性。如果你想实现特定的布局效果,使用 Flexbox 可以非常轻松地完成。

技术细节

1. 二宫格布局

scss
.gridWrap {
  display: flex;
  flex-wrap: wrap;

  .gridItem {
    flex: 1;
    flex-basis: 50%;
    box-sizing: border-box;

    &:nth-child(2n) {
      padding-left: 24rpx; // 希望两个之间有间隙的做法
    }
  }
}

实现这个左右效果不需要固定宽

左侧
右侧
scss
.infoItem {
  display: flex;
  align-items: center;

  .infoKey {
    flex: 1;
  }

  .infoValue {
    flex: 2;
  }
}

2. 三宫格布局-中间居中

scss
.wrap {
  display: flex;
  flex-wrap: wrap;

  .item {
    width: 32%;
    height: 100px;
    margin-bottom: 10px;
    background-color: #ccc;

    &:nth-child(3n+2) {
      margin-right: 2%;
      margin-left: 2%;
    }

    &:nth-child(3n+1) {
      margin-left: 0;
    }

    &:nth-child(3n+3) {
      margin-right: 0;
    }
  }
}

3. 四宫格布局-中间居中

scss
// 使用flex、gap属性来设置间隙
.imgWrap {
  width: 100%;
  max-height: 400px;
  display: flex;
  flex-wrap: wrap;
  padding: 20px 0;
  overflow-y: auto;
  gap: 16px;

  .imgWrap_item {
    width: calc(25% - 12px);
    height: 200px;
  }
}

// 或者使用margin来设置间隙
.imgWrap {
  width: 100%;
  max-height: 400px;
  display: flex;
  flex-wrap: wrap;
  padding: 20px 0;
  overflow-y: auto;
  margin: -8px;

  .imgWrap_item {
    position: relative;
    width: calc(25% - 16px);
    height: 200px;
    margin: 8px;
  }
}

4. 各种机型底部的安全区域

css
.item {
  padding-bottom: calc(env(safe-area-inset-bottom) + 20rpx);
}

5. 常用css

scss
.item {
  word-break: break-all; // 纯数字换行
  shape-outside: circle(50% at 50% 50%); // 不规则的文字环绕
  white-space: pre; // 文字两端对齐
}

// 滑动吸附效果--常见于swiper
.wrap {
  scroll-snap-type: x mandatory; // 可更换为proximity 表示为附近吸附

  .item {
    scroll-snap-align: start; // 排列
    scroll-snap-stop: always; // 吸附是否停止
  }
}

// 设置宽高比例
.box {
  width: 90%;
  aspect-ratio: 16/9;
}

// 逻辑属性
.box {
  margin-block: 5px 10px;    /* 上边距 5px,下边距 10px */
  margin-inline: 20px 30px;  /* 左边距 20px,右边距 30px */

  padding-block: 10px 20px;  /* 上下内边距 */
  padding-inline: 15px 25px; /* 左右内边距 */
}

// 平滑滚动
html {
  scroll-behavior: smooth;
}

6. css好网站

这里是一些优秀的网站资源,可以用于 CSS 相关的开发和设计:

以下是一些可以在线绘制 SVG 波浪效果的网站:

此外,以下是一些与 echarts 相关的网站资源:

  • PPChart - 提供多种样式的图表模板和代码示例。
  • madeapie - 一个在线生成 echarts 图表的工具。
  • echarts Demo 集 - 包含了丰富的 echarts 示例和演示。
  • MCChart - 提供多种样式的 echarts 图表模板。
  • echart 社区 - 一个 echarts 资源分享和交流的社区。

小小棱镜,无限可能