云筑文档(桌面端)
开发指南
快速上手
辅助
Utility辅助类
DataSet 数据集
dataHelper 数据请求助手
通用
icons svg
布局
grid 栅格
综合布局
表单
表 单
树
查找定义
下拉网格
扫码枪
复选框
级联选择
树选择
地图选择
baidu地图
上传
图片
组件
分页
下推
横向面板
纵向面板
排序面板
数据列表
条件面板
Excel导入
树查询面板
编辑器
表达式
上下文菜单
表格
工具条
流程测试
任务中心
图表
图片
对话框
动态组件
流程图
甘特图
calendar
进度条
导航菜单
折叠面板
本文档使用 MrDoc 发布
-
+
首页
grid 栅格
## 24 栅格系统 ### 设计理念  在多数业务情况下,Scp Design 需要在设计区域内解决大量信息收纳的问题,因此在 12 栅格系统的基础上,我们将整个设计建议区域按照 24 等分的原则进行划分。 划分之后的信息区块我们称之为『盒子』。建议横向排列的盒子数量最多四个,最少一个。『盒子』在整个屏幕上占比见上图。设计部分基于盒子的单位定制盒子内部的排版规则,以保证视觉层面的舒适感。 ### 概述 布局的栅格化系统,我们是基于行(row)和列(col)来定义信息区块的外部框架,以保证页面的每个区域能够稳健地排布起来。下面简单介绍一下它的工作原理: - 通过 `row` 在水平方向建立一组 `column`(简写 col) - 你的内容应当放置于 `col` 内,并且,只有 `col` 可以作为 `row` 的直接元素 - 栅格系统中的列是指 1 到 24 的值来表示其跨越的范围。例如,三个等宽的列可以使用 `<Col span={8} />` 来创建 - 如果一个 `row` 中的 `col` 总和超过 24,那么多余的 `col` 会作为一个整体另起一行排列 我们的栅格化系统基于 Flex 布局,允许子元素在父节点内的水平对齐方式 - 居左、居中、居右、等宽排列、分散排列。子元素与子元素之间,支持顶部对齐、垂直居中对齐、底部对齐的方式。同时,支持使用 order 来定义元素的排列顺序。 布局是基于 24 栅格来定义每一个『盒子』的宽度,但不拘泥于栅格。 ### 基础栅格 <div class="textDiv">  ------------ 通过` hi-row、hi-col` 标签初始化栅格布局。 ------------ 代码示例如下 ```html <template> <div class="docDemo-grid"> <hi-row> <hi-col span="24">col24</hi-col> </hi-row> <hi-row> <hi-col span="12">col-12</hi-col> <hi-col span="12">col-12</hi-col> </hi-row> <hi-row> <hi-col span="8">col-8</hi-col> <hi-col span="8">col-8</hi-col> <hi-col span="8">col-8</hi-col> </hi-row> <hi-row> <hi-col span="6">col-6</hi-col> <hi-col span="6">col-6</hi-col> <hi-col span="6">col-6</hi-col> <hi-col span="6">col-6</hi-col> </hi-row> <hi-row :gutter="16"> <hi-col span="6" class="gutter-row"> <div :style="style">col-6</div> </hi-col> <hi-col span="6" class="gutter-row"> <div :style="style">col-6</div> </hi-col> <hi-col span="6" class="gutter-row"> <div :style="style">col-6</div> </hi-col> <hi-col span="6" class="gutter-row"> <div :style="style">col-6</div> </hi-col> </hi-row> </div> </template> <script> export default { computed: { style() { return { background: "#0092ff", padding: "8px 0" }; }, }, }; </script> ``` </div> ### Col 提供 flex 属性以支持填充。 <div class="textDiv">  ------------ 通过 Flex 布局 ------------ 代码示例如下 ```html <template> <div class="docDemo-grid"> <div>flex排序</div> <hi-row > <hi-col :span="6" :order="4"> 1 col-order-4 </hi-col> <hi-col :span="6" :order="3"> 2 col-order-3 </hi-col> <hi-col :span="6" :order="2"> 3 col-order-2 </hi-col> <hi-col :span="6" :order="1"> 4 col-order-1 </hi-col> </hi-row> <div>flex占比</div> <hi-row> <hi-col :flex="2">2 / 5</hi-col> <hi-col :flex="3">3 / 5</hi-col> </hi-row> <div>flex固定大小</div> <hi-row> <hi-col flex="100px">100px</hi-col> <hi-col flex="auto">auto</hi-col> <hi-col flex="100px">100px</hi-col> </hi-row> <div>纵向 flex 固定大小</div> <hi-row isColumn style="height:500px"> <hi-col flex="100px">100px</hi-col> <hi-col flex="auto">auto</hi-col> </hi-row> </div> </template> <script> export default { computed: { style() { return { background: "#0092ff", padding: "8px 0" }; }, }, }; </script> ``` </div> ### API Scp Design 的布局组件若不能满足你的需求,你也可以直接使用社区的优秀布局组件: - react-flexbox-grid - react-blocks ### Row | 成员 | 说明 | 类型 | 默认值 | 版本 | | --- | --- | --- | --- | --- | | align | 垂直对齐方式 | `top` `middle` `bottom`| `top` | | | gutter | 栅格间隔,可以写成像素值或支持响应式的对象写法来设置水平间隔 `{ xs: 8, sm: 16, md: 24}`。或者使用数组形式同时设置 `[水平间距, 垂直间距]`。 | number、 object、 array | 0 | | | justify | 水平排列方式 | `start` `end` `center` `space-around` `space-between` | `start` | | ### Col | 成员 | 说明 | 类型 | 默认值 | 版本 | | --- | --- | --- | --- | --- | | flex | flex 布局属性,字符时 100px指占固定宽 | string 、number | - | | | offset | 栅格左侧的间隔格数,间隔内不可以有栅格 | number | 0 | | | order | 栅格顺序 | number | 0 | | | pull | 栅格向左移动格数 | number | 0 | | | push | 栅格向右移动格数 | number | 0 | | | span | 栅格占位格数,为 0 时相当于 display: none | number | - | | | xs | `<576px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、object | - | | | sm | `≥576px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、 object | - | | | md | `≥768px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、object | - | | | lg | `≥992px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、object | - | | | xl | `≥1200px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、object | - | | | xxl | `≥1600px` 响应式栅格,可为栅格数或一个包含其他属性的对象 | number 、object | - | | 响应式栅格的断点扩展自 BootStrap 4 的规则(不包含链接里 `occasionally` 的部分)。 <style> .textDiv{ border:1px solid #F5F5F5; padding: 20px 35px; border-radius: 4px; } .textDiv:hover{ border-color:#1890ff; } </style>
admin
2024年4月29日 16:28
分享文档
收藏文档
上一篇
下一篇
微信扫一扫
复制链接
手机扫一扫进行分享
复制链接
关于 MrDoc
鲲鹭文档MrDoc
是
州的先生
开发并开源的在线文档系统,其适合作为个人和小型团队的云笔记、文档和知识库管理工具。
如果鲲鹭文档给你或你的团队带来了帮助,欢迎对作者进行一些打赏捐助,这将有力支持作者持续投入精力更新和维护鲲鹭文档,感谢你的捐助!
>>>捐助鸣谢列表
微信
支付宝
QQ
PayPal
Markdown文件
分享
链接
类型
密码
更新密码