[Django] 我对dispatch的理解

views.py

javascript 复制代码
import json

from django.http import JsonResponse
from django.views import View
from myapp.models import UserKey


class Mysql_data(View):
    def dispatch(self, request, *args, **kwargs):
        action = kwargs.pop('action', None)
        if action == 'get_mysql_data':
            return self.mymodel_list(request, *args, **kwargs)
        if action == 'delete_data':
            return self.delete_data(request, *args, **kwargs)

    @staticmethod
    def mymodel_list(request):
        # values() 方法用于查询字段的数据。
        data = list(UserKey.objects.all().values())
        print(data)
        return JsonResponse({'my_data': data})

    @staticmethod
    def delete_data(request):
        mysql_data = json.loads(request.body)
        print(mysql_data)
        print(type(mysql_data))
        # # 根据id获取要删除的数据
        data = UserKey.objects.get(pk=mysql_data)
        # 删除数据
        a = data.delete()
        print(a)
        b = list(a)
        return JsonResponse({'status_code': 200, 'my_data': b})

重点

javascript 复制代码
class Mysql_data(View):
    def dispatch(self, request, *args, **kwargs):
        action = kwargs.pop('action', None)
        if action == 'get_mysql_data':
            return self.mymodel_list(request, *args, **kwargs)
        if action == 'delete_data':
            return self.delete_data(request, *args, **kwargs)

这一段代码中其他的都是固定的,主要看if语句和他的返回值,当action等于send_message时就调用main()函数,当action等于check_message时就调用post()函数,那么如何判断他的action?这就要在urls.py中设置:

urls.py

javascript 复制代码
from django.urls import path

from myapp.mysql_data import Mysql_data


# # 短信验证登录路由
urlpatterns = [
    # 显示数据库数据
    path('mysql_data/', Mysql_data.as_view(), {"action": "get_mysql_data"}),
    path('delete_data/', Mysql_data.as_view(), {"action": "delete_data"})
]

(FBV一般用于单个函数及其路由的调用,CBV用于两个及以上的函数调用路由,上面的urls.py里面就用了Django的CBV开发方法,详细看菜鸟教程;)

在path()中,使用了action 去分辨它。所以当调用mysql_data/ 路由时会执行mymodel_list函数 ,调用delete_data/ 路由时会调用delete_data函数;

相关推荐
NineData4 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师6 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石10 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker