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
    }

王伟路
1 声望0 粉丝