【Django-01】 视图函数和视图类

视图函数

作用

用于返回给前端数据

详解

python 复制代码
    def list(request):
        """
        1.普通的视图函数 request是HttpRequest 函数
        2.且必须用request.GET|request.POST 指定方法是什么方法
        3.返回值不能用 rest_framework包下的Response 必须是

        :param request:
        :return:
        """
        assert isinstance(request, HttpRequest)
        page = request.GET.get("page", default=1)
        page_size = request.GET.get("page_size", default=10)
        objs = Student.objects.all()
        # 分页器实现分页
        paginator = Paginator(objs, page_size)  # 构建分页器
        current_page_objs = paginator.get_page(page).object_list  # 当前页的数据
        # 反序列化为json
        data_list = StudentSerializer(current_page_objs, many=True).data
        res = {
            "status_code": 200,
            "message": "分业查询成功",
            "data": {
                'items': data_list
            }
        }
        return JsonResponse(res)

读者不需要看其他部分,只需要知道视图函数接收的是HttpRequest对象。

其属性有:

path:路径,不包含域名

method: 表示请求的方法,为str类型,值为POST, GET

encoding:数据的编码格式,默认utf-8

GET: 字典,包含get所有参数

POST:字典,POST所有参数

FILES:字典,上传文件的信息

COOKIES:字典 所有cookie对象

session:字典 表示会话

META: 字典,HTTP 头信息,比如agent,ip等

user:当前登录用户

视图函数的特点

视图函数,函数名称何以结合path达到词语达意的意思,比较灵活。比如函数名称为: list_stident(request)

则url中path('list/student', list_stident)

视图类

视图类是封装了接收前端 ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace'] 方法支持的类,想要任何函数直接继承APIView 即可,这样子固定的路径下,该类自动识别前端请求类型,会自动找到对应的函数,比如前段发送POST请求,则会自动到你实现的POST中。

实际开发怎么用

一般是视图函数和视图类结合使用。视图类只提供最基本的:【POST 创建 , PUT修改, DELETE 删除 , GET 创建四个函数】至于其他的api则用视图函数达到 见路径知含义的效果。

一个无意义的demo

java 复制代码
class StudentApi(APIView):
    """
    1.get/put/post/delte 定义了基础视图
    2.静态函数定义了 其他的功能
    """
    def get(self, request):
        queryset = Student.objects.all()
        data_list = StudentSerializer(queryset, many=True).data
        res = {
            "status_code": 200,
            "message": "查询成功",
            "data": {
                'items': data_list,
                'total': len(data_list)
            }
        }
        return Response(res)

    # 创建->仅仅传入data参数
    def post(self, request):
        with transaction.atomic():
            serializer = StudentSerializer(data=request.data)
            if serializer.is_valid(raise_exception=True):
                # save 中做了校验如果存在则更新  否则则是创建
                instance = serializer.save()

                res = {
                    "status_code": 200,
                    "message": "创建成功",
                    "data": {
                        'id': instance.id
                    }
                }
                return Response(res)

    # 更新要同时传入  instance 和data
    def put(self, request):
        with transaction.atomic():
            res_body = {
                "code": 200,
                "msg": "更新成功",
                "data": {}
            }
            try:
                obj = Student.objects.get(id=request.data['id'])
                serializer = StudentSerializer(instance=obj, data=request.data)
                if serializer.is_valid(raise_exception=True):
                    instance = serializer.save()
                    res_body["data"]["obj"] = model_to_dict(instance)
            except Exception as e:
                print(e)
                res_body["msg"] = "更新失败:%s" % e
            return Response(res_body)

    def delete(self, request):
        assert isinstance(request, Request)
        params = request.query_params
        res_body = {
            "code": 200,
            "msg": "删除",
            "data": {}
        }
        try:
            obj = Student.objects.get(id=params["id"])
            obj.delete()
            res_body["data"]["obj"] = model_to_dict(obj)
        except Exception as e:
            res_body["msg"] = "删除失败:%s" % e
        return Response(res_body)

    def list(request):
        """
        1.普通的视图函数 request是HttpRequest 函数
        2.且必须用request.GET|request.POST 指定方法是什么方法
        3.返回值不能用 rest_framework包下的Response 必须是

        :param request:
        :return:
        """
        assert isinstance(request, HttpRequest)
        page = request.GET.get("page", default=1)
        page_size = request.GET.get("page_size", default=10)
        objs = Student.objects.all()
        # 分页器实现分页
        paginator = Paginator(objs, page_size)  # 构建分页器
        current_page_objs = paginator.get_page(page).object_list  # 当前页的数据
        # 反序列化为json
        data_list = StudentSerializer(current_page_objs, many=True).data
        res = {
            "status_code": 200,
            "message": "分业查询成功",
            "data": {
                'items': data_list
            }
        }
        return JsonResponse(res)

路由定义为:
urlpatterns = [
    url(r'^student$', app_view.StudentApi.as_view()),//基本增删改查
    url('^student/list$', app_view.StudentApi.list)  //见path知含义
]
相关推荐
杰仔正在努力8 分钟前
python成长技能之枚举类
开发语言·python
Eiceblue15 分钟前
通过Python 调整Excel行高、列宽
开发语言·vscode·python·pycharm·excel
Jam-Young25 分钟前
Python中的面向对象编程,类,对象,封装,继承,多态
开发语言·python
酸奶代码25 分钟前
Spring AOP技术
java·后端·spring
Light6036 分钟前
低代码牵手 AI 接口:开启智能化开发新征程
人工智能·python·深度学习·低代码·链表·线性回归
代码小鑫36 分钟前
A034-基于Spring Boot的供应商管理系统的设计与实现
java·开发语言·spring boot·后端·spring·毕业设计
墨绿色的摆渡人37 分钟前
用 Python 从零开始创建神经网络(六):优化(Optimization)介绍
人工智能·python·深度学习·神经网络
paopaokaka_luck43 分钟前
基于Spring Boot+Vue的多媒体素材管理系统的设计与实现
java·数据库·vue.js·spring boot·后端·算法
小han的日常1 小时前
pycharm分支提交操作
python·pycharm
程序猿麦小七1 小时前
基于springboot的景区网页设计与实现
java·spring boot·后端·旅游·景区