admin.site.register(models.UserInfo)
admin.site.register(models.Book,Book_admin)
######当下面注册的这个表里面没有这个方法的时候,就是register后面没有这个admin的话,那么这个就默认会使用Modeladmin的方法
print(self_admin.site._register)##拿到所有的表的类对象,调用的是AdminSite里面的_register,里面封装了全部的(包括自己默认加的两个表[类对象])表
app_name=model._meta.app_label拿到这个类对象(表)的app名字
model_name=model._meta.model_name拿到这个表下面的所有字段
admin里面的所有的自定制:
list_display = ('__str__',)
list_display_links = ()
list_filter = ()
list_select_related = False
list_per_page = 100
list_max_show_all = 200
list_editable = ()
search_fields = ()
date_hierarchy = None
save_as = False
save_as_continue = True
save_on_top = False
paginator = Paginator
preserve_filters = True
inlines = [] # Custom templates (designed to be over-ridden in subclasses)
add_form_template = None
change_form_template = None
change_list_template = None
delete_confirmation_template = None
delete_selected_confirmation_template = None
object_history_template = None
popup_response_template = None # Actions
actions = []
action_form = helpers.ActionForm
actions_on_top = True
actions_on_bottom = False
actions_selection_counter = True
checks_class = ModelAdminChecks

自定制字段原理实现:(函数)
from django.utils.safestring import   mark_safe
class Book_admin(admin.ModelAdmin):
##自定制字段action,放在list_display里面进行渲染出来
def action(self):
##这传入的self相对应的表的类对象
return mark_safe('<a href="#">删除</a>')
list_display = ['num_user','user','room_name','time',action]
'''
讲解一下这个原理:
上面的这个函数的自定义字段的操作,是在modeladmin里面实际是这样来判断下面的list_display是字段,还是函数
当是函数,就拿这个返回值,拿到这个html在渲染出来(用模板语言)在后端进行的渲染,在浏览器里面解析出相对应的页面出来
当这个是字段的话,就是某一个表里面的字段,
实现代码:
tmp=[]
a=self.model.objects.all()
##这个slef.model是表对象,就是Book
for model_obj in a:
for field in list_display:
if callback(field):
print("是函数")
val=field(model_obj)
#这是进行的实例化操作,拿到这个返回的值,在浏览器解出来(在前端渲染出来)
tmp.appned(val)
else:
print('是字段')
val=field
tmp.append(val) ##在前端for循环一下,拿到所有的包括自定制的字段 {%for i in dic%}
<a>{{i}}</a>
{%endfor%}
'''

原理讲解:
不管下面你注册的是表后面有没有自定义的admin样式的时候,都存在注册的表的样式的类
当你没有配置这个样式的时候,就使用默认的样式类对象ModelAdmin
当你自己配置了这个样式的话,就使用你配置的类样式,自己配置的类样式也是继承了Adminadmin,也会执行这个类方法
'''

自定义admin:

admin部分
self_admin.site.register(Book, book_admin)
self_admin.site.register(UserInfo) url部分:
from  django.conf.urls  import url
from self_admin.server.self_admin import site
##所有的程序执行起来都是一个单例对象,一直都是一个程序在执行,只有第一个app是调用了site单例对象(modeladmin)
urlpatterns = [
path('admin/', admin.site.urls),
url(r'^self_admin/',site.urls),
url(r'^login',views.login),
url(r'^index/',views.index),
] self-admin部分:
from  django.shortcuts import   render,redirect,HttpResponse
from django.conf.urls import url class Self_Modeladmin(object):
def __init__(self,model,site):
self.model=model
self.site=site
print('Self_Modeladmin'*1000)
##########<class 'app01.models.Room'>
print(model)
print('*'*200)
def add(self,request):
print(self)
return HttpResponse(self.model._meta.model_name) def list(self,request): return HttpResponse(self.model._meta.app_label) def change(self,request,id): return HttpResponse(self.model._meta.app_label) ##通过传参数进来调用的时候,不用在加参数进来了,否则会重复
def delete(self,request,id): return HttpResponse(self.model._meta.app_label) ###########进行增删改查操作
'''
讲解:
当是加静态方法进行调用的时候,没有传一个参数进来,当没有加这个静态方法的时候,你会传参数进来,所以就可以在add函数
里面少传一个参数进来,注意区别
'''
@property
def get_url3(self):
dic=[]
##类下面的每一个实例对象都有一块独立的内存空间,这个增删改查是独立开来的
dic.append(url(r'^(\d+)/delete/',self.delete))
dic.append(url(r'^(\d+)/change/',self.change))
dic.append(url(r'^add/',self.add))
dic.append(url(r'^list/',self.list))
return dic,None,None class Self_AdminSite():
def __init__(self):
self._register={} ###这里面传入两个参数,后面的这个参数可以为空,后面的自定义的类可以为空,当为空的时候,就使用默认的modeladmin
def register(self,model,stark_class=None):
if not stark_class: #####假如没有自定义的类的话,就用父类样式
stark_class=Self_Modeladmin
self._register[model]=stark_class(model,self)#在这里已经传了两个参数进去,在了一个了里面可以直接进行调用
##注明一下,后面的这个模型类对象是有参数的(adminbook(book))这个是有传参数过去的 self.model=book这个是可以直接去取这个里面的数据的 @property
def get_urls(self):
dic = []
#注明一下,这个第一个是model表,第二个是自定义的类,字典里面有这两个值
for model,admin_class in self._register.items():
app_name=model._meta.app_label
model_name=model._meta.model_name##这个是字段的名字
# dic.append(url(r'^%s/%s/'%(app_name,model_name),(admin_class.get_url2,None,None)))
#在下面注明,当这个model有自定义部分的时候,这就是这个于自定义的类,当没有自定义的时候,这个就是默认的继承的父类的部分,样式(部分)
dic.append(url(r'^%s/%s/'%(app_name,model_name),admin_class.get_url3)) #上面的两种方法是一样的,这个之前调用的都是同一个类进行的调用 # dic.append(url(r'^%s/%s/'%(app_name,model_name),
# ([ url(r'^delete', slef_Modeladmin.list)],None,None
# ))) return dic @property
def urls(self): return self.get_urls,None,None
site=Self_AdminSite() #创建一个单例对象site

												

自定义admin(self_admin)的更多相关文章

  1. 自定义admin管理工具(stark组件)

    自定义admin管理工具(stark组件) 创建项目 了解了admin的功能后,我们可以开始仿照admin编写我们自己的管理工具stark组件 首先创建一个新的项目,并创建三个app stark就是我 ...

  2. 自定义admin

    平时我们用的django自带admin,怎么评价呢?一个字简陋,而且也人性化,如下图,首先只显示数据对象,如果要查看详细还有点进去,其次不能对自己想要的数据进行刷选 我们的期望是:数据如excel显示 ...

  3. Django 中自定义 Admin 样式与功能

    目录 自定义 Admin 样式与功能 1 页面修改中文 1.1 语言设置为中文 1.2 应用管理设置为中文 1.3 数据库表设置为中文 1.4 数据库表字段名称修改为中文 2 修改后台样式 2.1 安 ...

  4. Part 7:自定义admin站点--Django从入门到精通系列教程

    该系列教程系个人原创,并完整发布在个人官网刘江的博客和教程 所有转载本文者,需在顶部显著位置注明原作者及www.liujiangblog.com官网地址. Python及Django学习QQ群:453 ...

  5. 自定义admin组件

    配置路由 1 新建一个项目, 创建一个app01和stark应用,stark创建一个service包,并在service下创建stark.py.然后注册app 2 仿照site.py的注册代码,写st ...

  6. django自定义Admin actions

    通常情况下,admin的工作模式是“选中目标,然后修改目标”,但在同时修改大量目标的时候,这种模式就变得重复.繁琐. 为此,admin提供了自定义功能函数actions的手段,可以批量对数据进行修改. ...

  7. Django 自定义 admin

    为 model 自定义显示 label是这个Field如果在form中的话会显示的.而verbose_name在form中不会显示.只是作为一种说明而已 callable()   -->  是否 ...

  8. 第一个Django应用 - 第七部分:自定义admin

    Django的admin站点是自动生成的.高度可定制的,它是Django相较其它Web框架独有的内容,广受欢迎.如果你觉得它不够美观,还有第三方美化版xadmin.请一定不要忽略它,相信我,它值得拥有 ...

  9. 第五章:Admin管理后台 - 2:自定义Admin actions

    通常情况下,admin的工作模式是"选中目标,然后修改目标",但在同时修改大量目标的时候,这种模式就变得重复.繁琐. 为此,admin提供了自定义功能函数actions的手段,可以 ...

随机推荐

  1. 调用waitpid的SIGCHLD信号处理函数

    #include <stdio.h> #include <sys/wait.h> void sig_chld(int signo) { pid_t pid; int stat; ...

  2. redis的持久化方案

    Redis的高性能是由于其将所有数据都存储在了内存中,为了使Redis在重启之后仍能保证数据不丢失,需要将数据从内存中同步到硬盘中,这一过程就是持久化. Redis支持两种方式的持久化,一种是RDB方 ...

  3. luogu 4145 花神游历各国 线段树/树状数组+并查集

    此题一看便是RMQ问题,但是由于开平方的特殊操作,tag操作失效 此时发现特性:sqrt最多执行6此便使值到达1/0,此时可以剪枝不进行该操作,利用并查集到达特性找根,根代表还可以进行操作的点,再利用 ...

  4. 数组B:我想我需要一艘船屋

    Fred Mapper is considering purchasing some land in Louisiana to build his house on. In the process o ...

  5. 数据库设计理论与实践·<一>总结

    一.数据库生命周期 数据库生命周期流程图如下: 二.各阶段附图 附图1.1 数据流图 附图1.2 数据字典-方式1 补充说明:数据字典既可以单张表格表示,也可以多种(数据项表/数据结构表/数据流表/外 ...

  6. 【译】第四篇 SQL Server安全权限

    本篇文章是SQL Server安全系列的第四篇,详细内容请参考原文. 权限授予主体访问对象,以执行某些操作.SQL Server有大量你可以授予给主体的权限,你甚至可以拒绝或回收权限.这听起来有点复杂 ...

  7. Redis 深度历险

    学习资料 https://juejin.im/book/5afc2e5f6fb9a07a9b362527 包括下面几方面的内容 基础 应用 原理 集群 拓展 源码 to be done

  8. sql常用问题(一)

    一.sql要掌握 1.sum select  sum(score) from table 2.group select name, sum(score) from table group by 3.a ...

  9. 算法-链的操作(一)-合并两个排序的链接(no.25)

    合并两个排序的链接(no.25) 把下面连个排好序的链,从小到大排序链接. list1 : 1 -> 6 -> 8 list2 : 2-> 5 -> 9 def merge(h ...

  10. java json 转换

    1.直接输出: 2.字符串 通过eval转换输出,里面涉及到一个转义问题,还要注意eval的用法里面需要加"("+ + ")" 3.