Django REST framework+Vue 打造生鲜超市(九)
目录
生鲜超市(十) 生鲜超市(十一) 生鲜超市(十二) 生鲜超市(十三)
代码下载
教程
学习自慕课网-前端vue结合后端DjangoFramework的在线生鲜超市
十、购物车、订单管理和支付功能
10.1.添加商品到购物车
(1)trade/serializer.py
- # trade/serializer.py
- __author__ = 'derek'
- from .models import ShoppingCart
- from rest_framework import serializers
- from goods.models import Goods
- class ShopCartSerializer(serializers.Serializer):
- #获取当前登录的用户
- user = serializers.HiddenField(
- default=serializers.CurrentUserDefault()
- )
- nums = serializers.IntegerField(required=True, label="数量",min_value=1,
- error_messages={
- "min_value":"商品数量不能小于一",
- "required": "请选择购买数量"
- })
- #这里是继承Serializer,必须指定queryset对象,如果继承ModelSerializer则不需要指定
- #goods是一个外键,可以通过这方法获取goods object中所有的值
- goods = serializers.PrimaryKeyRelatedField(required=True, queryset=Goods.objects.all())
- #继承的Serializer没有save功能,必须写一个create方法
- def create(self, validated_data):
- # validated_data是已经处理过的数据
- #获取当前用户
- # view中:self.request.user;serizlizer中:self.context["request"].user
- user = self.context["request"].user
- nums = validated_data["nums"]
- goods = validated_data["goods"]
- existed = ShoppingCart.objects.filter(user=user, goods=goods)
- #如果购物车中有记录,数量+1
- #如果购物车车没有记录,就创建
- if existed:
- existed = existed[0]
- existed.nums += nums
- existed.save()
- else:
- #添加到购物车
- existed = ShoppingCart.objects.create(**validated_data)
- return existed
(2)trade/views.py
- # trade/views.py
- from rest_framework import viewsets
- from rest_framework.permissions import IsAuthenticated
- from utils.permissions import IsOwnerOrReadOnly
- from rest_framework_jwt.authentication import JSONWebTokenAuthentication
- from rest_framework.authentication import SessionAuthentication
- from .serializers import ShopCartSerializer
- from .models import ShoppingCart
- class ShoppingCartViewset(viewsets.ModelViewSet):
- """
- 购物车功能
- list:
- 获取购物车详情
- create:
- 加入购物车
- delete:
- 删除购物记录
- """
- permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
- authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication)
- serializer_class = ShopCartSerializer
- def get_queryset(self):
- return ShoppingCart.objects.filter(user=self.request.user
(3)配置url
- # 配置购物车的url
- router.register(r'shopcarts', ShoppingCartViewset, base_name="shopcarts")
10.1.添加购物车数量
Serializer继承BaseSerializer,但是Seriazer中并没有重新update方法,所有添加一个update方法
trade/serializer.py
- def update(self, instance, validated_data):
- # 修改商品数量
- instance.nums = validated_data["nums"]
- instance.save()
- return instance
在view中要把商品id传过去
- lookup_field = "goods_id"
10.3.vue和购物车接口联调
购物车中可以看商品详情,需要写一个商品详情的serializer,所有在view中需要动态设置serializer
(1)trade/serializer.py
- class ShopCartDetailSerializer(serializers.ModelSerializer):
- '''
- 购物车商品详情信息
- '''
- # 一个购物车对应一个商品
- goods = GoodsSerializer(many=False, read_only=True)
- class Meta:
- model = ShoppingCart
- fields = ("goods", "nums")
(2)trade/views.py
需要动态选择serializer
- def get_serializer_class(self):
- if self.action == 'list':
- return ShopCartDetailSerializer
- else:
- return ShopCartSerializer
10.4.订单管理接口
(1)trade/serializer.py
用户添加商品到购物车,点去购物车结算,填上地址留言,结算生成订单,在会员中心我的订单里面,可以看到订单列表,点订单可以看到订单的详细信息。
- #订单中的商品
- class OrderGoodsSerialzier(serializers.ModelSerializer):
- goods = GoodsSerializer(many=False)
- class Meta:
- model = OrderGoods
- fields = "__all__"
- #订单商品信息
- # goods字段需要嵌套一个OrderGoodsSerializer
- class OrderDetailSerializer(serializers.ModelSerializer):
- goods = OrderGoodsSerialzier(many=True)
- class Meta:
- model = OrderInfo
- fields = "__all__"
- class OrderSerializer(serializers.ModelSerializer):
- user = serializers.HiddenField(
- default=serializers.CurrentUserDefault()
- )
- #生成订单的时候这些不用post
- pay_status = serializers.CharField(read_only=True)
- trade_no = serializers.CharField(read_only=True)
- order_sn = serializers.CharField(read_only=True)
- pay_time = serializers.DateTimeField(read_only=True)
- nonce_str = serializers.CharField(read_only=True)
- pay_type = serializers.CharField(read_only=True)
- def generate_order_sn(self):
- #生成订单号
- # 当前时间+userid+随机数
- from random import Random
- random_ins = Random()
- order_sn = "{time_str}{userid}{ranstr}".format(time_str=time.strftime("%Y%m%d%H%M%S"),
- userid=self.context["request"].user.id,
- ranstr=random_ins.randint(10, 99))
- return order_sn
- def validate(self, attrs):
- #validate中添加order_sn,然后在view中就可以save
- attrs["order_sn"] = self.generate_order_sn()
- return attrs
- class Meta:
- model = OrderInfo
- fields = "__all__"
(2)trade/views.py
- class OrderViewset(mixins.ListModelMixin, mixins.RetrieveModelMixin, mixins.CreateModelMixin, mixins.DestroyModelMixin,
- viewsets.GenericViewSet):
- """
- 订单管理
- list:
- 获取个人订单
- delete:
- 删除订单
- create:
- 新增订单
- """
- permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
- authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication)
- serializer_class = OrderSerializer
- #动态配置serializer
- def get_serializer_class(self):
- if self.action == "retrieve":
- return OrderDetailSerializer
- return OrderSerializer
- #获取订单列表
- def get_queryset(self):
- return OrderInfo.objects.filter(user=self.request.user)
- #在订单提交保存之前还需要多两步步骤,所以这里自定义perform_create方法
- #1.将购物车中的商品保存到OrderGoods中
- #2.清空购物车
- def perform_create(self, serializer):
- order = serializer.save()
- # 获取购物车所有商品
- shop_carts = ShoppingCart.objects.filter(user=self.request.user)
- for shop_cart in shop_carts:
- order_goods = OrderGoods()
- order_goods.goods = shop_cart.goods
- order_goods.goods_num = shop_cart.nums
- order_goods.order = order
- order_goods.save()
- #清空购物车
- shop_cart.delete()
- return order
(3)配置url
- # 配置订单的url
- router.register(r'orders', OrderViewset, base_name="orders")
Django REST framework+Vue 打造生鲜超市(九)的更多相关文章
- Django REST framework+Vue 打造生鲜超市(三)
四.xadmin后台管理 4.1.xadmin添加富文本插件 (1)xadmin/plugins文件夹下新建文件ueditor.py 代码如下: # xadmin/plugins/ueditor.py ...
- Django REST framework+Vue 打造生鲜超市(四)
五.商品列表页 5.1.django的view实现商品列表页 (1)goods/view_base.py 在goods文件夹下面新建view_base.py,为了区分django和django res ...
- Django REST framework+Vue 打造生鲜超市(五)
六.商品类别数据展示 6.1. 商品类别数据接口 (1)商品分类有两个接口: 一种是全部分类:一级二级三级 一种是某一类的分类以及商品详细信息: 开始写商品分类的接口 (2)序列化 给分类添加三级分类 ...
- Django REST framework+Vue 打造生鲜超市(十二)
十三.首页.商品数量.缓存和限速功能开发 13.1.轮播图接口实现 首先把pycharm环境改成本地的,vue中local_host也改成本地 (1)goods/serializer class B ...
- Django REST framework+Vue 打造生鲜超市(八)
九.个人中心功能开发 9.1.drf的api文档自动生成和 (1) url #drf文档,title自定义 path('docs',include_docs_urls(title='仙剑奇侠传')), ...
- Django REST framework+Vue 打造生鲜超市(一)
一.项目介绍 1.1.掌握的技术 Vue + Django Rest Framework 前后端分离技术 彻底玩转restful api 开发流程 Django Rest Framework 的功能实 ...
- Django REST framework+Vue 打造生鲜超市(二)
三.Models设计 3.1.项目初始化 (1)进虚拟环境下安装 django2.0.2 djangorestframework和相关依赖mark,filter pillow 图片处理 pip in ...
- Django REST framework+Vue 打造生鲜超市(六)
七.用户登录与手机注册 7.1.drf的token (1)INSTALL_APP中添加 INSTALLED_APPS = ( ... 'rest_framework.authtoken' ) toke ...
- Django REST framework+Vue 打造生鲜超市(十)
十一.pycharm远程代码调试 第三方登录和支付,都需要有服务器才行(回调url),我们可以用pycharm去远程调试服务器代码 服务器环境搭建 以全新阿里云centos7系统为例: 11.1.阿里 ...
随机推荐
- V-bind详细使用
v-bind 主要用于属性绑定,Vue官方提供了一个简写方式 :bind,例如: <!-- 完整语法 --> <a v-bind:href="url">& ...
- 【Python】 获取MP3信息replica
replica 初衷是想要整理iphone中的音乐.IOS(我自己的手机还是IOS8.3,新版本的系统可能有变化了)自带的音乐软件中所有音乐文件都存放在/var/mobile/Media/iTunes ...
- 【Python】 sys和os模块
sys sys模块能使程序访问于python解释器联系紧密的变量和函数 ● sys中的一些函数和变量 argv 命令行参数构成的列表 path 查找所有可用模块所在的目录名的列表 platform 查 ...
- Nginx正向代理与反向代理
1.正向代理: 正向代理类似一个跳板机,代理访问外部资源. 典型应用:为在防火墙内的局域网客户端提供访问Internet的途径 如:IE例外设置代理服务器 正向代理配置实例:为不影响默认配置:添 ...
- 实现Windows程序的数据的绑定
1.创建DataSet对象 语法: DataSet 数据集对象 =new DataSet("数据集的名称字符串"); 语法中的参数是数据集的名称字符串,可以有,也可以没有.如 ...
- oracle管理权限和角色
介绍 这一部分主要看看oracle中如何管理权限和角色,权限和角色的区别在哪里. 当刚刚建立用户时,用户没有任何权限,也不能执行任何操作.如果要执行某种特定的数据库操作,则必需为其授予系统的权限:如果 ...
- [Scala] 实现 NDCG
一.关于 NDCG [LTR] 信息检索评价指标(RP/MAP/DCG/NDCG/RR/ERR) 二.代码实现 1.训练数据的加载解析 import scala.io.Source /* * 训练行数 ...
- UserControl 用户定义组件
<pages> <namespaces> <add namespace="System.Web.Optimization" /> </na ...
- 项目Alpha冲刺Day2
一.会议照片 二.项目进展 1.今日安排 初步搭建后台框架,根据昨天的最终设计再修改原型,成功使用powerDesigner导出sql. 2.问题困难 使用了比较多的框架,而且是首次尝试纯java配置 ...
- Flask 扩展 Flask-RESTful
Flask路由可以指定HTTP请求方法,并在请求函数中根据不同的请求方法,执行不同的逻辑.这样实现一个Restful的请求已经相当简单了 Flask还有更简便的方法,就是其Flask-RESTful扩 ...