模拟admin组件自己开发stark组件之自定义list_display,反向解析url
反向解析
在上一篇文章中,我们创建好了stark这个组件,一个应用一个表有四个默认的url,那么我们如何区别这些url,因为可能会有重复现象(本组件不会,因为前面拼接了应用名,表明,肯定唯一),概念请转至http://www.cnblogs.com/jokerbj/p/8337486.html反向解析,解决url重复问题
命名空间
我们解决了url问题,但是有可能每个应用下也会存在url相同,这个时候django只会标识其中一个,为了解决这个问题,我们加入命名空间概念,转至http://www.cnblogs.com/jokerbj/p/8337486.html
admin反向解析
我们针对上一篇文章在url上的修改为下面,在默认的样式类里面,而且是在首页上点击a标签
#================================= url相关解析
# 反向解析名称空间的增删改查
def get_edit_url(self,id): # 反向解析的url,传id肯定是修改或者删除
print('====',id)
c_url = "joker:%s_%s_edit" % (self.model._meta.app_label,self.model._meta.model_name)
print(c_url)
edit_url = reverse(c_url,args=(id,))
return edit_url
pass
def get_del_url(self,id): # 反向解析的url,传id肯定是修改或者删除
c_url = "joker:%s_%s_delete" % (self.model._meta.app_label, self.model._meta.model_name)
del_url = reverse(c_url, args=(id,))
return del_url def get_list_url(self): # 反向解析的url,传id肯定是修改或者删除
c_url = "joker:%s_%s_list" % (self.model._meta.app_label, self.model._meta.model_name)
list_url = reverse(c_url)
return list_url
#=================================显示的样式,和url的反向
# 我这里给予页面一些默认的按钮,选择按钮,操作按钮
def edit(self,obj=None,is_header=False): # 默认编辑按钮
if is_header:
return 'op'
else:
return mark_safe("<a href='%s'>edit</a>" % self.get_edit_url(obj.id)) # 调用反向解析出来的url def delete(self,obj=None,is_header=False): # 默认编辑按钮
if is_header:
return 'op'
else:
return mark_safe("<a href='%s'>del</a>" % self.get_del_url(obj.id)) def checkbox(self,obj=None,is_header=False): # 默认多选框
if is_header:
return 'select'
else:
return mark_safe("<input type='checkbox'>")
def get_urls(self): # 默认的增删改查 # 我这里获取的URL是不是应该加入别名?反向解析呢?
# url( 正则,视图(元祖,列表),命名空间)
app_model_name = (self.model._meta.app_label,self.model._meta.model_name) # 应用名称,表名称
temp=[
url("^$",self.list_view,name="%s_%s_list" % app_model_name),
url("^add/$",self.add_view,name="%s_%s_add" % app_model_name),
url("^(\d+)/change/$",self.change_view,name="%s_%s_edit" % app_model_name), ### 注意小括号
url("^(\d+)/delete/$",self.delete_view,name="%s_%s_delete" % app_model_name),
] return temp #============================url
@property # 获取URL
def urls(self):
return self.get_urls(), None, 'joker' # URL 第三个参数是命名空间 ### 注意这里我加入了名称空间
admin自定义显示内容
我们可以对用户自己控制的显示内容做显示,利用类的继承,重写,有自己的用自己的,没有用父类的
父类我们给予一些默认的,表头和数据,表头是'op',数据是一个带有反向解析的a标签
应用app01里面stark.py里面注册内容为
class bookjoker(joker.ModelAdmin): # 自定义样式类
list_display = ('id','title',) joker.site.register(models.Book,bookjoker)
在样式类获取页面要显示的dis_play
class ModelAdmin(object): # 默认样式 list_display = () # 自定义展示,用户有没有自定义
def get_list_display(self): # 得到需要展示的内容
default_list_display=[] if self.list_display:
default_list_display.extend(self.list_display)
default_list_display.append(ModelAdmin.edit) # 添加的是对象,不是字符串
default_list_display.append(ModelAdmin.delete) # 添加的是对象,不是字符串
default_list_display.insert(,ModelAdmin.checkbox) # 添加的是对象,不是字符串
else:
pass ####### 自定义如果是空,那么如何显示???,在下面判断 list_display为空,也就是用户为空 return default_list_display
样式类有个处理表头,和数据的,在list_vies上
def list_view(self,request):
# list_display = (checkbox,"id","title",edit,delete) # 处理表头,也就是第一行内容,如果数据库有verbose_name字段,就会拿到这个名称
head_list = []
for field_name in self.get_list_display(): # id title edit
if isinstance(field_name,str):
###### 字符串,肯定就是字段了,例如 title字段到这里,就会得到verbose_name名字,如果没有verbose_name那就是本身名称
verbox_name = self.model._meta.get_field(field_name).verbose_name
else:
# checkbox edit走这里
verbox_name = field_name(self,is_header=True) ##### 判断是不是头
head_list.append(verbox_name)
if not self.list_display: #### 没有list_display
head_list = ['选择',self.model._meta.model_name.upper(),] print('==head_list==',head_list) # ['ID', '书籍名称', 'op'] # 处理数据
data_list = self.model.objects.all() # 得到所有数据库数据
print('==data_list==',data_list) # <QuerySet [<Book: linux>, <Book: python>, <Book: go>]> new_data_list = [] # [[, 'linux', "<a href='1/chagnge'>edit</a>"], [, 'python', "<a href='2/chagnge'>edit</a>"], [, 'go', "<a href='3/chagnge'>edit</a>"]] for obj in data_list: # 每一个对象
temp = [] if not self.list_display: # 没有dis_play,给予默认头,信息,显示对象
temp.append(self.checkbox(obj))
temp.append(obj)
else:
for field_name in self.get_list_display(): # (checkbox,"id","title",edit,delete)
if isinstance(field_name,str):
var = getattr(obj,field_name) # 拿到对象相对应的字段的值
else:
var = field_name(self,obj) # 不是对象里面的字段,执行自己样式方法,但是我要把这个obj传过去,为了修改删除
temp.append(var) new_data_list.append(temp) print('==new_data_list==',new_data_list)
return render(request,"joker/change_list.html", locals())
模拟admin组件自己开发stark组件之自定义list_display,反向解析url的更多相关文章
- 模拟admin组件自己开发stark组件之创建篇
admin组件 admin组件为我们提供了针对django管理页面 我们先简短来看下django的admin组件的启动流程,注册流程,url匹配过程 启动注册 1. 扫描所有应用下的注册了应用中的ad ...
- 模拟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,所以只有源码没有测试数据! 源码都有注 ...
- 10.16 正式开发stark组件(一)
2018-10-16 17:26:44 Django MTV 路由配置里面有 反向解析 参考连接:https://www.cnblogs.com/yuanchenqi/articles/762993 ...
- Agile.Net 组件式开发平台 - 组件开发示例
所谓组件式开发平台,它所有的功能模块都是以组件的形式扩展的,下面我来演示一个简单的组件开发例程. Agile.Net开发管理平台项目,已经托管在开源中国码云平台(http://git.oschina. ...
- 10.15仿admin开发stark组件(一)
2018-10-15 12:28:50 越努力,越幸运!永远不要高估自己! 低调做人,高调做事! 明天开stark项目!! admin 参考连接: http://www.cnblogs.com/yua ...
- django 之 stark组件
----------------------------------------------------------------烦恼没完没了,内心动荡不安,呜呼哀哉. 一.有个特殊的需求,需要用sta ...
随机推荐
- 2017北京赛区J题
类型:三维动态规划 题目链接 题意: 合并连续石头块,最终要合并成一块,求时间最短,每次只能连续合并L~R块石头,不能合并成一块时输出-1 题解: 利用动态规划解决两种分问题 dp[l][r][k]: ...
- 初识jQuery(1)
1.Jquery是对JavaScript对象和函数的封装(JavaScript框架) 2.怎么使用Jquery 第一步:把js文件放入项目中 第二步:在页面引用jquery <script ty ...
- d3.js(v5.7)完整地画一个柱状图
一.首先定义画布大小以及绘画区域的位置(总不能顶着屏幕边沿画吧) 代码: 图示: 二.横.纵向坐标轴 代码: 图示: 三.添加矩形个文本以及上色 图示:
- keras系列︱利用fit_generator最小化显存占用比率/数据Batch化
本文主要参考两篇文献: 1.<深度学习theano/tensorflow多显卡多人使用问题集> 2.基于双向LSTM和迁移学习的seq2seq核心实体识别 运行机器学习算法时,很多人一开始 ...
- EasyPlayer Android基于ffmpeg实现播放(RTSP/RTMP/HTTP/HLS)同步录像功能
之前有博客专门介绍了EasyPlayer的本地录像的功能,简单来说,EasyPlayer是一款RTSP播放器,它将RTSP流里的音视频媒体帧解析出来,并用安卓系统提供的MediaMuxer类进行录像. ...
- [置顶]
【机器学习PAI实践九】如何通过机器学习实现云端实时心脏状况监测
背景 我们通过之前的案例已经为大家介绍了如何通过常规的体检数据预测心脏病的发生,请见http://blog.csdn.net/buptgshengod/article/details/53609878 ...
- Deep Learning深入浅出
作者:Jacky Yang链接:https://www.zhihu.com/question/26006703/answer/129209540来源:知乎著作权归作者所有.商业转载请联系作者获得授权, ...
- 异形Modbus客户端 和 异形modbus服务器之间的通讯 侦听模式的modbus-tcp客户端通讯
前言 本文将使用一个Github公开的组件技术来实现一个异形ModBus TCP的客户端,方便的对异形Modbus tcp的服务器进行读写,这个服务器可以是电脑端C#设计的,也可以是特殊设备实现的,也 ...
- 数据交换格式 —— JSON(JavaScript Object Notation)
当请求 headers 中,添加一个name为 Accept,值为 application/json 的 header(也即"我"(浏览器)接收的是 json 格式的数据),这样, ...
- 让ASP.NET第一次请求不变慢
网页开发者早期最常遇到一个问题,当网站布署到IIS时候,每当IIS或是Application Pool重启后,第一位进入网站的使用者,其体验往往第一个反应就是网站很慢,然后就一直询问IT为什么网站这么 ...