订单系统就该这么设计,稳的一批!

订单功能作为电商系统的核心功能,由于它同时涉及到前台商城和后台管理系统,它的设计可谓是非常重要的。就算不是电商系统中,只要是涉及到需要交易的项目,订单功能都具有很好的参考价值,说它是通用业务功能也不为过。今天就以mall项目中的订单功能为例,来聊聊订单功能的设计与实现。

mall项目简介

这里还是简单介绍下mall项目吧,mall项目是一套基于 SpringBoot + Vue + uni-app 的电商系统,目前在Github已有60K的Star,包括前台商城项目和后台管理系统,能支持完整的订单流程!涵盖商品、订单、购物车、权限、优惠券、会员等功能,功能很强大!

功能设计

首先我们来看下mall项目中订单功能的设计,由于订单功能同时涉及到前台商城和后台管理系统,这里将分别讲解。

后台管理系统

后台管理系统的订单模块主要包括订单管理、订单设置、退货原因设置、退货申请设置功能。

订单管理

后台管理员在订单列表中可以实现查看订单、删除订单、订单发货、订单跟踪等操作。

订单系统就该这么设计,稳的一批!_第1张图片

针对不同状态下的订单,后台管理员在订单详情页还可以实现修改收货人信息、修改费用信息、关闭订单、备注订单等操作

订单系统就该这么设计,稳的一批!_第2张图片

订单设置

后台管理员可以对订单实现一些基础设置,例如订单超过多少时间自动关闭等等。

订单系统就该这么设计,稳的一批!_第3张图片

退货申请处理

后台管理员可以对退货申请进行处理,比如说确认退货或拒绝退货。

订单系统就该这么设计,稳的一批!_第4张图片

退货原因设置

后台管理员还可以对退货的原因进行设置,以便前台用户退货是进行选择。

订单系统就该这么设计,稳的一批!_第5张图片

前台商城系统

我们将以mall项目的核心订单流程为例,来介绍下前台商城系统中的订单功能。

流程示意图

前台商城系统从加入购物车到完成订单的整个流程可以参考下图。

订单系统就该这么设计,稳的一批!_第6张图片

订单流程

  • 前台会员可以在前台商城中查看商品;

订单系统就该这么设计,稳的一批!_第7张图片

  • 前台会员点击加入购物车后查看购物车;

订单系统就该这么设计,稳的一批!_第8张图片

  • 前台会员点击去结算后创建订单;

订单系统就该这么设计,稳的一批!_第9张图片

  • 前台会员点击去结算后跳转到支付界面;

订单系统就该这么设计,稳的一批!_第10张图片

  • 前台会员确认支付后跳转到我的订单界面;

订单系统就该这么设计,稳的一批!_第11张图片

  • 后台管理系统收到订单;

订单系统就该这么设计,稳的一批!_第12张图片

  • 后台管理员点击订单发货进行发货操作;

订单系统就该这么设计,稳的一批!_第13张图片

  • 确认发货后,前台商城订单状态变为待收货;

订单系统就该这么设计,稳的一批!_第14张图片

  • 前台会员确认收货后,订单状态变为交易完成;

订单系统就该这么设计,稳的一批!_第15张图片

  • 后台管理系统可查看订单详情。

订单系统就该这么设计,稳的一批!_第16张图片

功能整理

对于订单模块的功能,我这里整理了一张思维导图方便大家查看,主要是整理了下有哪些功能以及功能需要涉及哪些字段。

订单系统就该这么设计,稳的一批!_第17张图片

数据库设计

根据我们的功能设计和整理好的思维导图,就可以进行数据库设计了,这里是mall项目订单模块的数据库设计图。

订单系统就该这么设计,稳的一批!_第18张图片

接口设计

对于mall项目中订单模块的接口设计,大家可以参考项目的Swagger接口文档,以Oms开头的接口就是订单模块对应的接口。

订单系统就该这么设计,稳的一批!_第19张图片

总结

今天介绍了下mall项目中订单模块的功能设计、数据库设计和接口设计,由于很多项目中都会涉及到订单功能,掌握订单功能的设计还是非常有必要的!

项目源码地址

https://github.com/macrozheng/mall

你可能感兴趣的:(订单系统就该这么设计,稳的一批!)