模拟admin组件自己开发stark组件之创建篇
admin组件
admin组件为我们提供了针对django管理页面
我们先简短来看下django的admin组件的启动流程,注册流程,url匹配过程
启动注册
1. 扫描所有应用下的注册了应用中的admin.py文件(启动,即扫描)
from django.contrib.admin.sites import site
from django.utils.module_loading import autodiscover_modules
def autodiscover():
autodiscover_modules('admin', register_to=site)
2. admin.site,这个文件是通过模块的导入然后调用类方法实现,并不是admin提供的方法(注册)
sites.py文件
site = AdminSite()
AdminSite类,包含了admin的全局配置
注意###
在admin.py里面,只有一个site对象,单例模式,以后的admin的应用都要基于 admin.site对象,也就是register也都是一个对象方法,
admin.site.register(book1)
admin.site.register(book2)
admin.site.register(book3) admin.site都是一个实例
3. admin.site.register,注册了model对象,样式类对象
2个参数,第一个models,第二个可以不传,默认为空,样式类
def register(self, model_or_iterable, admin_class=None, **options):
if not admin_class:
admin_class = ModelAdmin
如果是None就会走默认的ModelAdmin样式 如果不是None在admin里面继承了ModelAdmin样式,还在它的样式上有了自己的修改,也就是我们在admin.py里面自己的样式类 有段源码,最后的名字就是 model_or_iterable = model self._registry[model] = admin_class(model, self) 执行了就是在给类属性,添加键值对
booke:(book配合Modeladmin是实例出来的对)象】 如果再有注册,就是往后面追加键值对。model为键,样式为值
URL配置
urlpatterns = [
url(r'^admin/', admin.site.urls),
]
1. admin.site,还是上面的实例,也就是说所有的amdin.site都是一个实例,我们来看看里面的方法
@property
def urls(self):
return self.get_urls(), 'admin', self.name # 第一个参数是url列表,第二个是应用名称,第三个是命名空间
def get_urls(self):
urlpatterns = [
url(r'^$', wrap(self.index), name='index'),]
return urlpatterns
最终会返回一个([url(),url(),url()],admin,self.name)这样的元祖
2. 我们会这样想,一个项目下的一个应用下的一个表的增删改查,在这之前,我们先要拼接上app01/stark/book/(add,del,edit),我们来演演变过程
urls演变过程
url(r'^joker/', joker.site.urls),
# @property
# def urls(self):
# return self.get_urls(), 'stark', None
#self.get_urls() == admin.site.get_urls()
url(r'^joker/', ([url('','')], 'stark', None)),
我们希望可以拼接应用名称,表名称
def get_urls(self):
urlpatterns = []
for model, joker_admin in self._registry.items(): # 注册了就会得到2个对象,一个MODELS对象,一个样式类对象
model_name = model._meta.model_name # 应用名称
app_label = model._meta.app_label # 表名
# UR()方法,里面第一个参数是正则,第二个是可调用对象,或者列表,元祖。
# 如果是列表,元祖的话,
c_url = url('^{0}/{1}/'.format(app_label,model_name),增删改查) ## JOKER/APP01/BOOK, 分发
# [url("^$",self.change_list),
# url("^add/$",self.add),
# url("^\d+/change/$",self.change),
# url("^\d+/delete/$",self.delete),],NONE,NONE urlpatterns.append(c_url)
return urlpatterns @property
def urls(self): # 模拟了ADMIN的URLS方法,看返回的是什么(【】,NONE, NONE)
return self.get_urls(), None, None
我们希望增删改查是每一个表都有的,我们将这个加入到默认样式类中,这个就很简单了,下面奉上创建stark的过程和代码
stark创建
1. 创建stark目录,里面在创建server目录,里面创建stark.py文件,作为我们的服务目录
问题来了,谁来加载我们自己创建的目录呢,我们可以在stark应用下的apps.py中
from django.apps import AppConfig from django.contrib.admin.sites import site
from django.utils.module_loading import autodiscover_modules class starkConfig(AppConfig):
name = 'stark'
# 启动发现
def ready(self): 该类是默认就存在的,我们在下面加入准备方法,扫描所有应用下的stark.py文件
autodiscover_modules('stark', register_to=site)
2. 开始注册,在stark.py中写入
# print("app01 stark....") # 启动时候就会打印
from stark.server import stark
from .models import *
stark.site.register(Book) 加载执行
stark.site.register(Publish)
3. 服务端的stark.py的配置,注意里面的url方法
from django.conf.urls import url
from django.shortcuts import HttpResponse # 首先是启动问题 settingS 注册,apps可以查询到 class ModelAdmin(object): # 默认样式
def __init__(self,model,site):
self.model = model
self.site = site def get_urls(self): # 默认的增删改查 temp=[
url("^$",self.change_list),
url("^add/$",self.add),
url("^\d+/change/$",self.change),
url("^\d+/delete/$",self.delete),
] return temp @property # 获取URL
def urls(self):
return self.get_urls(), None, None # URL 就是 三个参数,(【】,,) def change_list(self,request):
return HttpResponse("change_list") def delete(self,request):
return HttpResponse("delete") def change(self,request):
return HttpResponse("change") def add(self,request):
return HttpResponse("add") class Jokersite(object): # 针对JOKER的全局配置
def __init__(self):
self._registry = {}
def register(self, model, joker_class=None):
if not joker_class:
joker_class = ModelAdmin
self._registry[model] = joker_class(model, self) # 添加类对象,MODEL对象:样式类对象
print(self._registry) def get_urls(self): urlpatterns = []
for model, joker_admin in self._registry.items(): # 注册了就会得到2个对象,一个MODELS对象,一个样式类对象
model_name = model._meta.model_name # 应用名称
app_label = model._meta.app_label # 表名
# UR()方法,里面第一个参数是正则,第二个是可调用对象,或者列表,元祖。
# 如果是列表,元祖的话,
c_url = url('^{0}/{1}/'.format(app_label,model_name),joker_admin.urls) ## stark/APP01/BOOK, 分发
# [url("^$",self.change_list),
# url("^add/$",self.add),
# url("^\d+/change/$",self.change),
# url("^\d+/delete/$",self.delete),],NONE,NONE urlpatterns.append(c_url)
return urlpatterns @property
def urls(self): # 模拟了ADMIN的URLS方法,看返回的是什么(【】,NONE, NONE)
return self.get_urls(), None, None site=Jokersite() # 实例自己写的类
模拟admin组件自己开发stark组件之创建篇的更多相关文章
- 模拟admin组件自己开发stark组件之自定义list_display,反向解析url
反向解析 在上一篇文章中,我们创建好了stark这个组件,一个应用一个表有四个默认的url,那么我们如何区别这些url,因为可能会有重复现象(本组件不会,因为前面拼接了应用名,表明,肯定唯一),概念请 ...
- 模拟admin组件自己开发stark组件之搜索和批量操作
搜索相关,搜索的本质就是从数据库查询出来的数据过滤 用户自定义给出过滤条件joker.py list_display = ('id','title','price',) show_add_btn = ...
- 模拟admin组件自己开发stark组件之增删改查
增删改查,针对视图 我们需要modelform来创建,可自动生成标签,我们还要考虑用户是不是自己定制,依然解决方法是,继承和重写 app01下的joker.py文件 class BookModelFo ...
- 在WePY中实现了小程序的组件化开发,组件的所有业务与功能在组件本身实现,组件与组件之间彼此隔离,上述例子在WePY的组件化开发过程中,A组件只会影响到A所绑定的myclick
wepyjs - 小程序组件化开发框架 https://tencent.github.io/wepy/document.html#/?id=%e5%be%ae%e4%bf%a1%e5%b0%8f%e7 ...
- 10.18正式开发stark组件*(三)
2018-10-18 19:15:54 等这个stark组件做完了再上传到github上面,然后再整理博客!这就到周末啦! 因为models导入的时候出现bug,所以只有源码没有测试数据! 源码都有注 ...
- Agile.Net 组件式开发平台 - 组件开发示例
所谓组件式开发平台,它所有的功能模块都是以组件的形式扩展的,下面我来演示一个简单的组件开发例程. Agile.Net开发管理平台项目,已经托管在开源中国码云平台(http://git.oschina. ...
- 10.15仿admin开发stark组件(一)
2018-10-15 12:28:50 越努力,越幸运!永远不要高估自己! 低调做人,高调做事! 明天开stark项目!! admin 参考连接: http://www.cnblogs.com/yua ...
- 10.16 正式开发stark组件(一)
2018-10-16 17:26:44 Django MTV 路由配置里面有 反向解析 参考连接:https://www.cnblogs.com/yuanchenqi/articles/762993 ...
- django 之 stark组件
----------------------------------------------------------------烦恼没完没了,内心动荡不安,呜呼哀哉. 一.有个特殊的需求,需要用sta ...
随机推荐
- dubbo 之filter使用
1.继承接口com.alibaba.dubbo.rpc.Filter实现public Result invoke(Invoker<?> invoker, Invocation invoca ...
- Python中基本的读文件和简单数据处理
Python中基本的读文件和简单数据处理 暂无评论 DataQuest上面的免费课程(本文是Python基础课程部分),里面有些很基础的东西(csv文件读,字符串预处理等),发在这里做记录.涉及下面六 ...
- BGP选路原则
bgp选路原则 1 最高有weight优先,默认为0(思科特有,选大的) 2 本地优先级高的优先(只可以在IBGP邻居之间传递) 3 起源本路由器上的路由(network.aggregate-addr ...
- iOS-----获取当前app的名称和版本号
iOS获取当前App的名称和版本号 第一步 如图中Info.plist中鼠标点击右键,出现选项框,选着" Show Raw Keys/Values " 第二步 用下面代码就可以获取 ...
- 【剑指offer】两个链表的第一个公共结点,C++实现
原创文章,转载请注明出处! 博客文章索引地址 # 题目 #举例 如果两个单向链表有公共的节点,那么这两个链表从第一个公共结点开始,之后所有结点都是重合的,不可能再出现分叉.拓扑结构如下图所示: # 思 ...
- Mini Stirling engine
So I spent 5 or 6 hours last night trying to hook up a mini Stirling engine with the gearbox of a Ta ...
- Vim:基础
Normal模式 即是command “vim test.txt” 时进入的界面. 常用command: :help<Enter> 查看命令. :wq<Enter> ...
- 20179223《Linux内核原理与分析》第一周学习笔记
第一周实验 尝试创建两个文件,用通配符查找这两个文件:在创建文件的时候,需要同时创建多个文件的方法运行. 根据作业要求,实现一个lilux命令. 根据作业要求添加一个用户loutest,使用sudo创 ...
- Java8新特性——StreamAPI(二)
1. 收集器简介 收集器用来将经过筛选.映射的流进行最后的整理,可以使得最后的结果以不同的形式展现. collect方法即为收集器,它接收Collector接口的实现作为具体收集器的收集方法. Col ...
- 《DSP using MATLAB》示例Example7.5
代码: h = [-4, 1, -1, -2, 5, 6, 6, 5, -2, -1, 1, -4]; M = length(h); n = 0:M-1; [Hr, w, b, L] = Hr_Typ ...