xadmin系列之django的url分发的方式
一、先介绍一下我们自己的urls中是如何进行路由分发的
一、一级路由
urlpatterns = [
url(r'^upload/', views.upload,name="upload"),
url(r'^article-site/(?P<auther>\w+)', views.article_site,name="article"),
url(r'^login/', views.login,name="bbs_login"),
url(r'^index/', views.index,name="bbs_index"),
url(r'^register/', views.register,name="bbs_register"),
url(r'^logout/', views.logout, name="bbs_logout"),
url(r'^up_down/', views.up_down,name="up_down"),
url(r'^add_comment/', views.add_comment,name="add_comment"),
url(r'^comment_tree/(?P<nid>\d+)', views.comment_tree,name="comment_tree"),
url(r'^(?P<name>\w+)/$', views.blog,name="bbs_blog"),
url(r'^(?P<name>\w+)/(?P<tid>\d+)/$', views.article), ]
二、二级路由
from django.conf.urls import include
url(r'^app1/',include("app1.urls")),
三、路由分发,这里还可以里面在嵌套一层
url(r'^cui/', (
[url(r'^test1/', test.test1),
url(r'^test2/', test.test2),
url(r'^test3/', test.test3),
]
,None,None)),
二、下面看下django的admin是如何进行路由分发的
django的admin就是用上面的第三种方式实现urls的分发
先掌握一个知识点
a、通过表的对象去获取表的名称,这里需要注意,获取到的表名是全小写的
from app1.models import Article
Article._meta.model_name
'article'
b、通过表的对象获取该表所属的app的名称
Article._meta.app_label
'app1'
下面我们用路由分发的方式进行分发,我们要一个类似这样的url
cui/app的名称/表的名称/add/ -------增加
cui/app的名称/表的名称/list/ --------查看
cui/app的名称/表的名称/1/change----编辑
cui/app的名称/表的名称/1/del-----删除
下面看下我们定义的函数geturls函数,这个函数的主要的目的就是获取表的名称和表所属的app的名称
def geturls():
temp = []
for model,admin_class in admin.site._registry.items():
# 通过表的对象获取表的名称
model_name = model._meta.model_name # 通过表的对象获取表的app的名称
app_name = model._meta.app_label temp.append(
url(r'^{app_name}/{model_name}/'.format(app_name=app_name,model_name=model_name), (geturlsoperation(),None,None))
)
return temp
这里我们为上面用到的admin.site._registry这个函数呢?我们看下源码
在admin.site文件中最后返回了一个对象,我们导入admin.site就相当于导入了一个AdminSite的对象,而这个对象和我们前面学的非常的相似,他就是一个单实例的对象
我们看下AdminSite这个类的
class AdminSite(object):
"""
An AdminSite object encapsulates an instance of the Django admin application, ready
to be hooked in to your URLconf. Models are registered with the AdminSite using the
register() method, and the get_urls() method can then be used to access Django view
functions that present a full admin interface for the collection of registered
models.
""" # Text to put at the end of each page's <title>.
site_title = ugettext_lazy('Django site admin') # Text to put in each page's <h1>.
site_header = ugettext_lazy('Django administration') # Text to put at the top of the admin index page.
index_title = ugettext_lazy('Site administration') # URL for the "View site" link at the top of each admin page.
site_url = '/' _empty_value_display = '-' login_form = None
index_template = None
app_index_template = None
login_template = None
logout_template = None
password_change_template = None
password_change_done_template = None def __init__(self, name='admin'):
self._registry = {} # model_class class -> admin_class instance
self.name = name
self._actions = {'delete_selected': actions.delete_selected}
self._global_actions = self._actions.copy()
all_sites.add(self)
这里我们可以看到_registry是一个字典,我们在看下AdminSite这个类的register这个函数是如何使用这个变量的
def register(self, model_or_iterable, admin_class=None, **options):
"""
Registers the given model(s) with the given admin class. The model(s) should be Model classes, not instances. If an admin class isn't given, it will use ModelAdmin (the default
admin options). If keyword arguments are given -- e.g., list_display --
they'll be applied as options to the admin class. If a model is already registered, this will raise AlreadyRegistered. If a model is abstract, this will raise ImproperlyConfigured.
"""
if not admin_class:
admin_class = ModelAdmin if isinstance(model_or_iterable, ModelBase):
model_or_iterable = [model_or_iterable]
for model in model_or_iterable:
if model._meta.abstract:
raise ImproperlyConfigured(
'The model %s is abstract, so it cannot be registered with admin.' % model.__name__
) if model in self._registry:
raise AlreadyRegistered('The model %s is already registered' % model.__name__) # Ignore the registration if the model has been
# swapped out.
if not model._meta.swapped:
# If we got **options then dynamically construct a subclass of
# admin_class with those **options.
if options:
# For reasons I don't quite understand, without a __module__
# the created class appears to "live" in the wrong place,
# which causes issues later on.
options['__module__'] = __name__
admin_class = type("%sAdmin" % model.__name__, (admin_class,), options) # Instantiate the admin class to save in the registry
self._registry[model] = admin_class(model, self)
这里就是一个字典,字典的k表的对象,v是这个表的对象对应的admin_class,admin_class其实就是我们注册的时候的类
class ad(admin.ModelAdmin): def manyTomany(self):
return mark_safe("<a>删除</a>") list_display = ["content","article",manyTomany] # 控制admin显示某张标签的那些字段 # 这里我们还可以自定义一个字段,函数名就是字段的名称,函数的值就是字段的返回值 list_editable = ["article"]
# 定义那些字段可以在编辑,可以表的页面直接编辑 list_display_links = ["content","article"]
# 控制那些字段可以点击进入某张表的详情 admin.site.register(models.ArticleDetail,ad)
就是我们这个ad
我们在看下geturlsoperation这个函数,他就是返回我们的增删改查的
def geturlsoperation():
temp = []
temp.append(
url(r'^$',test.list_view)
)
temp.append(
url(r'^add/$',test.add_view)
)
temp.append(
url(r'^(?P<cid>\d+)/change/$',test.change_view)
)
temp.append(
url(r'^(?P<did>\d+)/del/$',test.del_view)
)
return temp
xadmin系列之django的url分发的方式的更多相关文章
- django的url分发封装
h2, body>h3, body>h4, body>h1{ padding: 10px; background-color: #4cae4c; text-align: center ...
- Django学习之十一:真正理解Django的路由分发和反解url原理
目录 URL Dispatcher 简介 模式概念 对比URLPattern 与 URLResolver (多态的体现) 构建子路由几种方式 反解url算法逻辑 URL Dispatcher 简介 d ...
- django url分发,视图,模板回顾
Django基础轮廓 MTV+controller 一 url分发系统: 1 简单使用 url(r'^articles/2003/$', views.special_case_2003), # spe ...
- Django url分发到工程里
因为我们建立了Django后 ,url是在mysite下的全局对象 因为我们实际项目里不可能只有一个工程 而全放在全局里去分发url 会让代码耦合度提高,代码量大后会造成维护困难.这时候我们把url分 ...
- Django路由配置之子路由include(URL分发)
子路由include(URL分发) 在一个项目中可能存在多个应用,为了方便区分和管理,在项目的总路由urls.py中会进行路由分发: (1)项目总路由导入from django.conf.urls ...
- day53:django:URL别名/反向解析&URL分发&命名空间&ORM多表操作修改/查询
目录 1.URL别名&反向解析 2.URL分发&命名空间 3.ORM多表操作-修改 4.ORM多表操作-查询 4.1 基于对象的跨表查询 4.2 基于双下划线的跨表查询 4.3 聚合查 ...
- day 82 URL分发
一 .admin 流程 (1) 启动 autodiscover_modules('admin', register_to=site) (2) 注册 单例模式 admin.site=AdminSite( ...
- Django的URL调度
1.URLconf (URL configuration):(Django版本1.11.20,其它版本可能各有差异.) 在Django中Python后端与前端URL进行交互,是通过一个名为urlcon ...
- Django的URL路由系统
一. URL配置 URL配置就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图之间的映射表.你就是以这种方式告诉Django,对于哪个URL调用的这段代码. 基本格式 from ...
随机推荐
- python 之列表推导式,集合推导式,以及字典推导式
https://www.cnblogs.com/weihengblog/p/8428124.html
- 服务限流-令牌桶java实现
此文非常不错,抄自: https://www.cnblogs.com/googlemeoften/p/6020718.html 其他实现 https://www.cnblogs.com/LBSer/p ...
- BroadcastReceiver的使用,动态注册和注销,优先级和中断控制
BroadcastReceiver: BroadcastReceiver(广播接收器)是Android中的四大组件之一,用来通知某些事件的相关信息,如下载完成,设置改变等. 默认的BroadcastR ...
- Redis使用认证密码登录
Redis默认配置是不需要密码认证的,也就是说只要连接的Redis服务器的host和port正确,就可以连接使用.这在安全性上会有一定的问题,所以需要启用Redis的认证密码,增加Redis服务器的安 ...
- 使用pt-table-checksum及pt-table-sync校验复制一致性
一.简介 pt-table-checksum是percona-toolkit系列工具中的一个, 可以用来检测主. 从数据库中数据的一致性.其原理是在主库上运行, 对同步的表进行checksum, 记录 ...
- How to Pronounce the 50 States
How to Pronounce the 50 States (1/4) Share Tweet Share Tagged With: Places The US state names can be ...
- Haskell语言学习笔记(73)Existentials
Existentials(存在类型) Existentially quantified types(Existentially types,Existentials)是一种将一组类型归为一个类型的方式 ...
- Linux创建SSH信任关系
Linux服务器创建信任关系可以解决远程执行命令.远程传输文件多次手工输入的麻烦.可以实现环境一键打包备份. 测试环境 SuSE 手工创建 假设服务器A与B间要建立信任关系.用户想从服务器A免密码登录 ...
- android如何快速查看APK包名和activity
一.通过ADB命令 1.dos进入 2.输入adb shell登录 3.输入dumpsys package | grep eggs(过滤相关包名) 二.通过日志查看包名() 1.连接设备 2.cmd命 ...
- Python类的进阶.md
属性绑定 在python中可以给类对象动态的绑定属性 但是由于这种特性,随意动态绑定也会带来麻烦,因此可用__slots__来限制可绑定的属性名称 __slots__的绑定对于子类是不生效的,只对当前 ...