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 }