1、订单页面总共分为3个部分
一、订单准备页面:
新建两个数据库表,一个是订单表 一个是订单商品表,一对多的关系,方便对订单数据进行存储和管理,
需要根据用户信息(request.user)从后台获取用户的地址信息(未删除的),展示到前端;然后需要获取用户的购物车信息(已勾选的商品和件数),也就是上文中构建的new_cart_dict = {},根据sku获取商品价格,然后乘以商品总价加上运费即可获取订单总金额;此外需要用户选中收货地址和支付方式响应给下一个页面,即订单展示页面;
二、订单展示页面:
2.1接收前端传来的两个数据,即收货地址和支付方式,获取用户信息。
2.2生成订单id(日期+时间+用户id);
2.3初始化订单数量0订单金额0;
2.4组织订单状态(如果是货到付款,则订单状态为待发货,如果是支付宝,则显示为待付款);
2.5.订单商品信息(我们从redis中获取选中的商品信息)
2.5.1 连接redis
2.5.2 获取hash
2.5.3 获取set
2.5.4 类型转换,转换过程中重新组织数据
选中的数据
{sku_id:count,sku_id:count}
2.5.5 获取选中的商品id [1,2,3]
2.5.6 遍历id
2.5.7 查询count
2.5.8 判断库存是否少于订单,如果没少则继续,如果少了则反馈库存不足
2.5.9 减少MySQL中该sku的库存值,增加spu和sku的销量值
2.5.10 保存商品信息,示例如下:
OrderGoods.objects.create(
order=order,
sku=sku,
count=count,
price=sku.price
)
2.5.11 累加计算 总金额和总数量
2.6. 保存订单信息的修改
三、订单成功页面:
响应信息如下:
context = {
'order_id': order_id,
'payment_amount': payment_amount,
'pay_method': pay_method
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。