[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函数;

相关推荐
海南java第二人2 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat2 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中2 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪2 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客3 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP4 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_4 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬5 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存
sukioe5 小时前
Redis 持久化+高可用详解:RDB/AOF/混合/主从/哨兵/集群
数据库·redis·缓存