在这个组件中有内置的4个处理函数,它们都有自己对应的url,那么它们的url是怎么构造的呢?

...

urlpatterns = [
re_path('list/$', self.wrapper(self.changelist_view), name=self.get_list_url_name ),
re_path('add/$', self.wrapper(self.add_view), name=self.get_add_url_name),
re_path('(?P<pk>\d+)/change/$', self.wrapper(self.change_view), name=self.get_edit_url_name),
re_path('(?P<pk>\d+)/del/$', self.wrapper(self.del_view), name=self.get_del_url_name), ]
...

可以看出来,都是根据url的name反向解析生成对应的url。先changelist_view这个函数为例进行说明。

    @property
def get_list_url_name(self):
return self.get_url_name('changelist') def get_url_name(self,param):
app_label = self.model_class._meta.app_label
model_name = self.model_class._meta.model_name
if self.prev:
name='%s_%s_%s_%s' % (app_label, model_name,self.prev,param)
else:
name='%s_%s_%s' % (app_label, model_name,param)
return name

在这里它的name就是命名空间+app名字+model名字+前缀+参数+changelist,前缀就是之前提到_registry={}换成_registy=[]用于区别同一个model产生不同页面进行区别的,而参数是干什么的呢?这里支持不仅可以用这内置的四个函数,而且也可以支持自己自定义自己的函数。

    def get_urls(self):
urlpatterns = [
re_path('audit/$', self.wrapper(self.changelist_view), name=self.get_url_name('audit_list') ),
]
extra_urls = self.extra_urls() if extra_urls:
urlpatterns.extend(extra_urls) return urlpatterns

看见没,audit_list就是参数,自己自定义的url name,这就形成了多个url访问同一个changlist_view函数,但是可以通过list_display等功能控制具体显示什么。这就是url name的构建。接下来就是怎么反向生成url了。

    def reverse_changelist_url(self,*args,**kwargs):
namespace = self.site.namespace
list_url = reverse('%s:%s' % (namespace, self.get_list_url_name),args=args,kwargs=kwargs)
origin_url = self.request.GET.get(self.back_condition_key) if not origin_url:
return list_url list_url = "%s?%s" % (list_url, origin_url) # /stark_config/app01/userinfo/list/?q=k
return list_url

这是反向生成列表页的url,将生成的列表页的url name反向解析,可能有的人要问了为什么后面会有*args以及**kwargs参数,看一个例子就明白了。

    def display_order(self, row=None, header_body=False,*args,**kwargs):
if not header_body:
return '订单记录'
url = reverse("stark:crm_order_changelist",kwargs={'customer_id':row.pk}) #注意小写表名
return mark_safe("<a href='%s'>订单记录</a>"%url)

这样避免了在url后面加?进行传值,相对来说简单一些。另外注意到了吗,这里还有保存上一次请求参数的功能。

 origin_url = self.request.GET.get(self.back_condition_key) 

这就是列表页url的构建,其余的就是编辑、删除、修改页面url的构建。

    def get_url_name(self,param):
app_label = self.model_class._meta.app_label
model_name = self.model_class._meta.model_name
if self.prev:
name='%s_%s_%s_%s' % (app_label, model_name,self.prev,param)
else:
name='%s_%s_%s' % (app_label, model_name,param)
return name @property
def get_edit_url_name(self):
return self.get_url_name('change') @property
def get_add_url_name(self):
return self.get_url_name('add') @property
def get_del_url_name(self):
return self.get_url_name('del')

反向解析url

   def reverse_edit_url(self,*args,**kwargs):
return self.reverse_common_url(self.get_edit_url_name,*args,**kwargs) def reverse_del_url(self,*args,**kwargs): return self.reverse_common_url(self.get_del_url_name,*args,**kwargs) def reverse_add_url(self,*args,**kwargs): return self.reverse_common_url(self.get_add_url_name,*args,**kwargs)
    def reverse_common_url(self,name,*args,**kwargs):
common_name = "%s:%s" % (self.site.namespace, name,)
base_url = reverse(common_name,args=args,kwargs=kwargs)
if not self.request.GET:
com_url=base_url
else:
param_str = self.request.GET.urlencode()
new_query_dict = QueryDict(mutable=True)
new_query_dict[self.back_condition_key] = param_str
com_url = "%s?%s" % (base_url, new_query_dict.urlencode(),)
return com_url

这样就完成各个视图函数动态url的生成。

stark组件之处理函数动态url构造(五)的更多相关文章

  1. stark组件开发之自动生成URL

    app01\model.py from django.db import models # Create your models here. class Depart(models.Model): i ...

  2. stark组件(2):提取公共视图函数、URL分发和设置别名

    效果图: Handler类里处理的增删改查.路由分发.给URL设置别名等包括以后还要添加的很多功能,每一个数据库的类都需要,所以我们要把Handler提取成一个基类.提取成基类后,每一个数据表都可以继 ...

  3. stark组件(1):动态生成URL

    项目启动时自动生成URL 效果图: 知识点: Django启动前通过apps下的ready方法执行一个可以生成URL的py文件 include函数主要返回有三个元素的一个元组.第一个是url配置(ur ...

  4. stark组件配置,二层URL

    1.django的admin配置 2 stark组件开发 3.2层url分发 4.小结 1.django的admin配置 model.py from django.db import models # ...

  5. stark 组件 url 二级分发的实现

    模拟 admin 组件url设计思路 项目urls 文件中: from django.contrib import admin from django.urls import path from st ...

  6. 7 stark组件介绍、配置、2层url

    1.django的admin配置 model.py from django.db import models # Create your models here. class UserInfo(mod ...

  7. stark组件的分页,模糊查询,批量删除

    1.分页组件高阶 2.整合展示数据showlist类 3.stark组件之分页 3.stark组件之search模糊查询 4.action批量处理数据 4.总结 1.分页组件高阶 1.分页的class ...

  8. stark组件之创建

    stark组件之需求 仿照Django中的admin , 开发了自己的stark组件,实现类似数据库客户端的功能,对数据进行增删改查 . stark之创建 1.在项目中 创建stark应用,app01 ...

  9. 24.stark组件全部

    admin组件: 博客里面的图片的是在太难弄了,有大哥会弄给我贴一片博客,我一个一个加太累了,没有加 admin参考:https://www.cnblogs.com/yuanchenqi/articl ...

随机推荐

  1. 整体二分例题:POI2011Meteors——Chemist

    题目地址:https://www.luogu.org/problemnew/show/P3527#sub 首先这个答案不是操作几次下了几场陨石雨之后的陨石个数,无法在线做,考虑离线做法.暴力的想法就是 ...

  2. [ZPG TEST 114] 阿狸的英文名【水题】

    1.      阿狸的英文名 阿狸最近想起一个英文名,于是他在网上查了很多个名字.他发现一些名字可以由两个不同的名字各取一部分得来,例如John(约翰)的前缀 “John”和Robinson(鲁滨逊) ...

  3. 扩展KMP的应用

    扩展KMP的应用: 给出模板串S和串T,长度分别为Slen和Tlen,要求在线性时间内,对于每个S[i](0<=i<Slen),求出S[i..Slen-1]与T的 最长公共前缀长度,记为e ...

  4. 题解报告:hdu 1114 Piggy-Bank(完全背包恰好装满)

    Problem Description Before ACM can do anything, a budget must be prepared and the necessary financia ...

  5. Uncaught TypeError: Cannot set property 'f7View' of undefined 错误原因

    // 添加视图var mainView = myApp.addView('.view-main', { // 因为我们要用动态的导航栏,我们需要使它的这一观点: dynamicNavbar: true ...

  6. RabbitMQ六:通过routingkey模拟日志

    序言 本章文章进入深入了解RabbiMQ,平时项目中我们经常用到记录日志,常见的不外乎:Info.debug.warn.Error.     情境进入:先简单说一下我们需求,我们开发过程中会遇到很多日 ...

  7. SpringBoot2.1.3修改tomcat参数支持请求特殊符号

    最近遇到一个问题,比如GET请求中,key,value中带有特殊符号,请求会报错,见如下URL: http://xxx.xxx.xxx:8081/aaa?key1=val1&a.[].id=1 ...

  8. 聊聊mq的使用场景

    mq的作用 通过异步方式对系统解耦 增加系统的并发处理能力 通过异步方式对系统解耦 以用户注册为例,一般情况下: 分下一下,上面过程存在的一些问题: 注册过程会调用4个服务(注册服务.邮件服务.短信服 ...

  9. hihocoder offer收割编程练习赛12 C 矩形分割

    思路: 模拟,深搜. 实现: #include <iostream> #include <cstdio> #include <string> using names ...

  10. 前端css3样式前缀自动补全工具--autoprefixer

    最近在学习一份来自git的动画框架源码,看懂70%的核心代码后,打算自己动手实践一版,然鹅,所有框架搭起来以后,在动画这块却出了问题: 想设计一个slideInLeft的动画,必然想到了要从偏移-10 ...