mirror of
https://github.com/nocobase/nocobase
synced 2024-11-16 14:28:26 +00:00
b8d0ad8fbc
* feat: update docs * feat: update docs * fix: update docs * Add files via upload * Add files via upload * Update the-first-app.md * Update the-first-app.md * Update v08-changelog.md * feat: update docs Co-authored-by: Zhou <zhou.working@gmail.com>
97 lines
4.1 KiB
Markdown
Executable File
97 lines
4.1 KiB
Markdown
Executable File
# 第一个 APP
|
||
|
||
让我们用 NocoBase 搭建一个订单管理系统。
|
||
|
||
## 1. 创建数据表和字段
|
||
|
||
在这个订单管理系统中,我们需要掌握`Customers`、`Products`、`Orders`的信息,他们彼此之间互相关联。经过分析,我们需要建立 4 个数据表,它们的字段分别为:
|
||
|
||
- Customers
|
||
- 姓名
|
||
- 地址
|
||
- 性别
|
||
- 电话
|
||
- *订单(购买过的所有订单,数据来自`Orders`,每条顾客数据包含多条订单数据)*
|
||
- Products
|
||
- 商品名称
|
||
- 描述
|
||
- 图片
|
||
- 价格
|
||
- Orders
|
||
- 订单编号
|
||
- 总价
|
||
- 备注
|
||
- 地址
|
||
- *顾客(该订单所属的顾客,数据来自`Customers`,每条订单数据属于一条顾客数据)*
|
||
- *订单明细(该订单中的商品,数据来自`Order Details`,每条订单数据包含多条订单明细数据)*
|
||
- Order list
|
||
- *订单(该明细所属的订单,数据来自`Orders`,每条订单明细数据属于一条订单数据)*
|
||
- *商品(该明细所包含的商品,数据来自`Products`,每条订单明细数据包含一条商品数据)*
|
||
- 数量
|
||
|
||
其中,斜体的字段是关系字段,关联到其他数据表。
|
||
|
||
接下来,点击“数据表配置”按钮,进入数据表配置界面,创建第一个 Collection `Customers`。
|
||
|
||
![create-collection.gif](./the-first-app/create-collection.gif)
|
||
|
||
然后点击“字段配置”,为`Customers` 添加 name 字段,它是单行文本类型。
|
||
|
||
![create-field.gif](./the-first-app/create-field.gif)
|
||
|
||
用同样的方法,为`Customers` 添加 Address、Gender、Phone,它们分别是单行文本、单项选择类型、手机号码类型。
|
||
|
||
![fields-list.jpg](./the-first-app/fields-list.jpg)
|
||
|
||
用同样的方法,创建 Collection `Products`、`Orders`、`Order list` 以及它们的字段。
|
||
|
||
|
||
|
||
![collection-list.jpg](./the-first-app/collection-list.jpg)
|
||
|
||
其中,对于关系字段,如果你不熟悉一对多、多对多等概念,可以直接使用 Link to 类型来建立数据表之间的关联。如果你熟悉这几个概念,请正确使用 One to many, Many to one 等类型来建立数据表之间的关联。比如在这个例子中,我们将 `Orders` 与 `Order list` 关联,关系为 One to many。
|
||
|
||
![collection-list.jpg](./the-first-app/order-list-relation.jpg)
|
||
|
||
|
||
在图形化的数据表里,可以很直观的看出各个表之间的关系。(注:Graph-collection 插件暂未开源)
|
||
|
||
![graph-collection.jpg](./the-first-app/graph-collection.jpg)
|
||
|
||
|
||
将数据表和字段创建完成后,我们开始制作界面。
|
||
|
||
## 2. 配置菜单和页面
|
||
|
||
我们需要顾客、订单、商品三个页面展示和管理我们的数据。
|
||
|
||
点击界面配置按钮,进入界面配置模式。在界面配置模式下,我们可以添加菜单项,添加页面,在页面内布置区块。
|
||
|
||
![1.editor.gif](./the-first-app/1.editor.gif)
|
||
|
||
点击添加菜单项,添加菜单分组 “Customers” 和 “Orders & Products” ,然后添加子菜单页面 “All Orders” 和 “Products”。
|
||
|
||
![1.menu.gif](./the-first-app/1.menu.gif)
|
||
|
||
添加完菜单和页面之后,我们可以在页面内添加和配置区块了。
|
||
|
||
## 3. 添加和配置区块
|
||
|
||
NocoBase 目前支持表格、看板、日历、表单、详情等类型的区块,它们可以将数据表中的数据展示出来,并可以对数据进行操作。显然,顾客、订单、商品 都适合用表格的方式展示和操作。
|
||
|
||
我们在“所有订单”页面,添加一个表格区块,数据源选择 Collection `Orders` ,并为这个表格区块配置需要显示的列。
|
||
|
||
![1.block.gif](./the-first-app/1.block.gif)
|
||
|
||
给这个表格区块配置操作,包括筛选、添加、删除、查看、编辑。
|
||
|
||
![1.action.gif](./the-first-app/1.action.gif)
|
||
|
||
为新增、编辑、查看等操作配置表单和详情区块。
|
||
|
||
![1.action-block.gif](./the-first-app/1.action-block.gif)
|
||
|
||
然后,用同样的方法,在 Products 和 Customers 页面布置表格区块。完成后,退出界面配置模式,进入使用模式,一个简单的订单管理系统就完成了。
|
||
|
||
![demo-finished.jpg](./the-first-app/demo-finished.jpg)
|