DRF 商城项目 - 用户操作(收藏, 留言, 收货地址)
个人收藏
整体逻辑类似于 个人中心 ( 个人中心的相关逻辑梳理详情 点击这里 )
也是两个序列化组价的分流
查看收藏 ( list ) 详情指向 收藏详情 的组价
创建收藏 ( create ) 指向 用户收藏 的组件
序列化组件
收藏详情需要用到收藏的商品全部内容, 序列化的时候需要进行组件的嵌套, 将商品序列化组件嵌进去
# 收藏详情
class UserFavDetailSerializer(serializers.ModelSerializer):
goods = GoodsSerializer(many=True) class Meta:
model = UserFav
fields = ("goods", "id")
收藏的时候需要注意设置一个联合唯一索引, 在序列化中设置后或者 models 中设置皆可
# 用户收藏
class UserFavSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
) class Meta:
model = UserFav
# 联合唯一可以在 model 中创建的时候进行操作, 通过 ModelSerializer 自然会帮你完成验证
# 也可以在这里完成, 注意是在 Meta 中进行设置, 因为这是多字段的处理
validators = [
UniqueTogetherValidator(
queryset=UserFav.objects.all(),
fields=('user', 'goods'),
message="已经收藏过了"
)
]
fields = ("user", "goods", "id") # 删除的需要因此加上 id, 这样方便删除操作
视图
整体逻辑类似于个人中心
依旧是 分流处理序列化组件, 因为收藏功能的全部请求都需要在用户登录下查看
因此不需认证分流
# 用户收藏功能
class UserFavViewset(mixins.CreateModelMixin, mixins.ListModelMixin, mixins.RetrieveModelMixin,
mixins.DestroyModelMixin, viewsets.GenericViewSet):
"""
list:
获取用户收藏列表
retrieve:
判断某个商品是否已经收藏
create:
收藏商品
destroy:
取消商品收藏
"""
# queryset = UserFav.objects.all() # 只能看自己的收藏记录
permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
serializer_class = UserFavSerializer
authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication)
lookup_field = "goods_id" # 分流处理 序列化组件
def get_serializer_class(self):
if self.action == "list":
return UserFavDetailSerializer
elif self.action == "create":
return UserFavSerializer
return UserFavSerializer def get_queryset(self):
return UserFav.objects.filter(user=self.request.user)
用户留言
基本上所用的字段什么的在上面都有用过了
序列化组件
需要注意的是留言时间的格式, 以及只读属性
注意 user 字段的传入应该是默认的当前用户, 且此字段可以设置成隐藏
# 用户留言
class LeavingMessageSerializer(serializers.ModelSerializer):
# 设置隐藏字段
user = serializers.HiddenField(
# 默认值为当前用户
default=serializers.CurrentUserDefault()
)
# 留言的时间不能自己指定, 应该是系统自动根据当前的时间, 因此设置为只读
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserLeavingMessage
fields = ("user", "message_type", "subject", "message", "file", "id", "add_time")
视图
# 用户留言
class LeavingMessageViewset(mixins.ListModelMixin, mixins.DestroyModelMixin, mixins.CreateModelMixin,
viewsets.GenericViewSet):
"""
list:
获取用户留言
create:
添加留言
delete:
删除留言功能
""" permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication)
serializer_class = LeavingMessageSerializer def get_queryset(self):
return UserLeavingMessage.objects.filter(user=self.request.user)
用户收货地址
基本上和留言一样了.
序列化组件
# 收货地址
class AddressSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
)
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserAddress
fields = ("id", "user", "province", "city", "district", "address", "signer_name", "add_time", "signer_mobile")
视图
# 收货地址
class AddressViewset(viewsets.ModelViewSet):
"""
收货地址管理
list:
获取收货地址
create:
添加收货地址
update:
更新收货地址
delete:
删除收货地址
""" permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication)
serializer_class = AddressSerializer def get_queryset(self):
return UserAddress.objects.filter(user=self.request.user)
全部代码
替换视图序列化
# _*_ coding:utf-8 _*_
from rest_framework.validators import UniqueTogetherValidator from goods.serializers import GoodsSerializer __author__ = "yangtuo"
__date__ = "2019/4/18 20:31" from rest_framework import serializers from .models import UserFav, UserLeavingMessage, UserAddress # 收藏详情
class UserFavDetailSerializer(serializers.ModelSerializer):
goods = GoodsSerializer() class Meta:
model = UserFav
fields = ("goods", "id") # 用户收藏
class UserFavSerializer(serializers.ModelSerializer):
# 用户就使用当前的默认用户, 并且设置为隐藏
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
) class Meta:
model = UserFav
# 联合唯一可以在 model 中创建的时候进行操作, 通过 ModelSerializer 自然会帮你完成验证
# 也可以在这里完成, 注意是在 Meta 中进行设置, 因为这是多字段的处理
validators = [
UniqueTogetherValidator(
queryset=UserFav.objects.all(),
fields=('user', 'goods'),
message="已经收藏过了"
)
]
fields = ("user", "goods", "id") # 删除的需要因此加上 id, 这样方便删除操作 # 用户留言
class LeavingMessageSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
)
# 留言的时间不能自己指定, 应该是系统自动根据当前的时间, 因此设置为只读
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserLeavingMessage
fields = ("user", "message_type", "subject", "message", "file", "id", "add_time") # 收货地址
class AddressSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
)
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserAddress
fields = ("id", "user", "province", "city", "district", "address", "signer_name", "add_time", "signer_mobile")
用户操作视图
# _*_ coding:utf-8 _*_
from rest_framework.validators import UniqueTogetherValidator from goods.serializers import GoodsSerializer __author__ = "yangtuo"
__date__ = "2019/4/18 20:31" from rest_framework import serializers from .models import UserFav, UserLeavingMessage, UserAddress # 收藏详情
class UserFavDetailSerializer(serializers.ModelSerializer):
goods = GoodsSerializer() class Meta:
model = UserFav
fields = ("goods", "id") # 用户收藏
class UserFavSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
) class Meta:
model = UserFav
# 联合唯一可以在 model 中创建的时候进行操作, 通过 ModelSerializer 自然会帮你完成验证
# 也可以在这里完成, 注意是在 Meta 中进行设置, 因为这是多字段的处理
validators = [
UniqueTogetherValidator(
queryset=UserFav.objects.all(),
fields=('user', 'goods'),
message="已经收藏过了"
)
]
fields = ("user", "goods", "id") # 删除的需要因此加上 id, 这样方便删除操作 # 用户留言
class LeavingMessageSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
)
# 留言的时间不能自己指定, 应该是系统自动根据当前的时间, 因此设置为只读
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserLeavingMessage
fields = ("user", "message_type", "subject", "message", "file", "id", "add_time") # 收货地址
class AddressSerializer(serializers.ModelSerializer):
user = serializers.HiddenField(
default=serializers.CurrentUserDefault()
)
add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta:
model = UserAddress
fields = ("id", "user", "province", "city", "district", "address", "signer_name", "add_time", "signer_mobile")
DRF 商城项目 - 用户操作(收藏, 留言, 收货地址)的更多相关文章
- Django电商项目---完成用户中心(订单中心+收货地址)day7
完成用户中心(收货地址) df_user/views.py df_user/urls.py templates/df_user/user_center_site.html 界面显示 完成用户中心(全部 ...
- DRF 商城项目 - 用户( 登录, 注册,登出,个人中心 ) 逻辑梳理
用户登录 自定义用户登录字段处理 用户的登录时通过 手机号也可以进行登录 需要重写登录验证逻辑 from django.contrib.auth.backends import ModelBacken ...
- Django商城项目笔记No.16用户部分-用户中心收货地址
首先完成省市区三级联动 新建areas应用 python ../../manage.py startapp areas 模型类代码 class Area(models.Model): "&q ...
- DRF 商城项目 - 购物( 购物车, 订单, 支付 )逻辑梳理
购物车 购物车模型 购物车中的数据不应该重复. 即对相同商品的增加应该是对购买数量的处理而不是增加一条记录 因此对此进行联合唯一索引, 但是也因此存在一些问题 class ShoppingCart(m ...
- 42 Flutter仿京东商城项目 修改默认收货地址 显示默认收货地址
CheckOut.dart import 'package:flutter/material.dart'; import '../services/ScreenAdapter.dart'; impor ...
- 41 Flutter 仿京东商城项目签名验证 增加收货地址、显示收货地址 事件广播
加群452892873 下载对应41课文件,运行方法,建好项目,直接替换lib目录 AddressAdd.dart import 'package:dio/dio.dart'; import 'pac ...
- 39 Flutter仿京东商城项目 收货地址列表、增加 修改收货地址布局、弹出省市区选择器
加群452892873 下载对应39课文件,运行方法,建好项目,直接替换lib目录 pubspec.yaml city_pickers: ^ AddressAdd.dart import 'packa ...
- HMS Core定位服务在生活服务类App中可以自动填写收货地址啦
在涉及团购.外卖.快递.家政.物流.搬家等生活服务类的App.小程序中,填写收货地址是用户高频使用的功能.这一功能通常采取让用户手动填写的解决方案,例如上下拉动选择浙江省-->杭州市--> ...
- 微信小程序-收货地址左滑删除
我参照了其中的部分代码,如:bindtouchstart,bindtouchmove,bindtouchend事件多数组中偏移值的更改, 在结合微信 movable-area 和 movable-vi ...
随机推荐
- DSAPI 截取被遮挡的窗口图像
Me.BackgroundImage=DSAPI.控件.截取窗体或控件图像(目标窗口句柄) 支持截取被覆盖或隐藏的窗口.
- ACCP8.0 HTML标签
ACCP8.0 HTML标签 第一章1.HTML超文本标记语言2.网页<html></html>3.网页头部<head></head>4.网页标题< ...
- json属性名必须加引号的讨论
优质参考资料: 1.https://blog.csdn.net/Goskalrie/article/details/52151175 2.https://blog.csdn.net/weixin_42 ...
- MySQL 笔记整理(12) --为什么我的MySQL会“抖”一下?
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> (本篇内图片均来自丁奇老师的讲解,如有侵权,请联系我删除) 12) --为什么我的MySQL会“抖”一下? 断更了一段时间,因为这几 ...
- Kafka学习资料
博客系列: Apache Kafka简介Apache Kafka安装和使用Apache Kafka核心概念kafka核心组件和流程—控制器kafka核心组件和流程—协调器kafka核心组件和流程—日志 ...
- 如何利用U盘重装系统
第一步,下载系统镜像 推荐在msdn上面下载,因为大多数都是 Microsoft 纯净原版镜像,如果要安装的是纯净版系统请先看第六步,然后才看第二步 第二步,下载U盘PE工具 推荐使用大白菜或者老毛桃 ...
- java基础(一):谈谈java内存管理与垃圾回收机制
看了很多java内存管理的文章或者博客,写的要么笼统,要么划分的不正确,且很多文章都千篇一律.例如部分地方将jvm笼统的分为堆.栈.程序计数器,这么分太过于笼统,无法清晰的阐述java的内存管理模型: ...
- Java实现"命令式"简易文本编辑器原型
源自早先想法, 打算从界面方向做些尝试. 找到个简单文本编辑器的实现: Simple Text Editor - Java Tutorials. 原本的菜单/按钮界面如下. 包括基本功能: 新建/打开 ...
- mysql很有用的语句
1)删除表内所有数据: 再添加数据时,如果设有自动增加的id,那么id也会重置. truncate table 表名; 2)创建结构相同的数据库表 create table 数据库名.新表名 like ...
- nlp中文分词(jieba和pyltp)
分词是中文自然语言处理的基础.目前常用的分词算法有 1.张华平博士的NShort中文分词算法. 2.基于条件随机场(CRF)的中文分词算法. 这两种算法的代表工具包分别是jieba分词系统和哈工大的L ...