10.15仿admin开发stark组件(一)
2018-10-15 12:28:50
越努力,越幸运!永远不要高估自己!
低调做人,高调做事!
明天开stark项目!!
admin 参考连接: http://www.cnblogs.com/yuanchenqi/articles/8323452.html
admin里面的一些配置
admin.py
from django.contrib import admin from .models import * # 带*的是必回的,其他了解,重点的注意 list_filter
class BookConfig(admin.ModelAdmin):
list_display=["id","user","room","date","time_id"] # 不能放多对多字段 *
list_display_links=["user"] # *
list_filter=["user","room","date"] # *
list_editable=["room"] # 不能和list_display_links 重复 #date_hierarchy = "date"
#fields=["user","room"]
#exclude=["user","room"] ordering=["date","time_id"] # 排序 # 定制Action行为具体方法 *
def func(self, request, queryset): print(self, request, queryset)
queryset.update(date="2012-12-12") func.short_description = "批量初始化操作"
actions = [func, ] class UserConfig(admin.ModelAdmin):
list_display = ["username","tel"]
list_filter = ["gf","username"]
search_fields=["username","tel"] admin.site.register(Book,BookConfig) #print(admin.site._registry) admin.site.register(UserInfo,UserConfig)
admin.site.register(Room)
admin.site.register(GF)
仿照admin的url注册:
就是一级分发到二级分发,然后返回一个([], None, None)
贴上源码
urls.py
from django.conf.urls import url
from django.contrib import admin
from app01 import views
from django.shortcuts import HttpResponse def yuan(request): return HttpResponse("Yuan") def test01(request): return HttpResponse("test01") def test02(request): return HttpResponse("test02") def test03(request): return HttpResponse("test03") def test04(request): return HttpResponse("test04") def test05(request): return HttpResponse("test05") def add(request):
return HttpResponse("add")
def delete(request,id):
return HttpResponse("delete")
def change(request,id):
return HttpResponse("change")
def list_view(request):
return HttpResponse("list_view") def get_urls2(): temp=[]
temp.append(url(r"^add/",add))
temp.append(url(r"^(\d+)/delete/",delete))
temp.append(url(r"^(\d+)/change/",change))
temp.append(url(r"^$",list_view))
return temp def get_urls(): temp=[]
print("_registry",admin.site._registry) for model,admin_class_obj in admin.site._registry.items():
print("model",model) # 所有的注册模型表 # < class 'app01.models.Book'>-----> "book" "app01"
# < class 'app01.models.Room'>-----> "room" "app01"
# print("===>",model._meta.model_name)
# print("===>",model._meta.app_label)
model_name=model._meta.model_name
app_label=model._meta.app_label
temp.append(url(r"%s/%s/"%(app_label,model_name),(get_urls2(),None,None))) return temp urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
url(r'^login/', views.login),
url(r'^book/', views.book), url(r"^yuan/",(get_urls(),None,None)) ]
笔记
day87 权限
会议室预定
admin与stark 复习面向对象知识 crm admin 使用 知识点1: url()的使用 情况1:url(r'^book/', views.book), # book(request) 情况2 分发:
url(r"^yuan/", ([
url(r'^test01/', ([
url(r'^test04/', test04),
url(r'^test05/', test05),
], None, None)),
url(r'^test02/', test02),
url(r'^test03/', test03),
], None, None)
) 知识点2: 单例模式
生成单例模式的方式:
(1)使用 __new__
(2)使用模块
class A()
pass
a=A() admin源码: 1 注册 admin.py admin.site.register(Book,BookConfig) 源码: class AdminSite():
def __init__(self, name='admin'):
self._registry = {} def register(self,model,admin_class):
if not admin_class:
admin_class = ModelAdmin self._registry[model] = admin_class(model, self) site=AdminSite() 2 设计url 如何通过model类变量获取该模型的字符串名称和该模型所在app的字符串名称:
print("===>", model._meta.model_name)
print("===>", model._meta.app_label)
################################################################### def add(request):
return HttpResponse("add")
def delete(request,id):
return HttpResponse("delete")
def change(request,id):
return HttpResponse("change")
def list_view(request):
return HttpResponse("list_view") def get_urls2(): temp=[]
temp.append(url(r"^add/",add))
temp.append(url(r"^(\d+)/delete/",delete))
temp.append(url(r"^(\d+)/change/",change))
temp.append(url(r"^$",list_view))
return temp def get_urls(): temp=[]
print("_registry",admin.site._registry) for model,admin_class_obj in admin.site._registry.items():
print("model",model) # 所有的注册模型表 # < class 'app01.models.Book'>-----> "book" "app01"
# < class 'app01.models.Room'>-----> "room" "app01"
# print("===>",model._meta.model_name)
# print("===>",model._meta.app_label) model_name=model._meta.model_name
app_label=model._meta.app_label
temp.append(url(r"%s/%s/"%(app_label,model_name),(get_urls2(),None,None))) return temp urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
url(r'^login/', views.login),
url(r'^book/', views.book), url(r"^yuan/",(get_urls(),None,None)) ] restful
vue
路飞学城
10.15仿admin开发stark组件(一)的更多相关文章
- 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 ...
- admin源码解析以及仿照admin设计stark组件
---恢复内容开始--- admin源码解析 一 启动:每个APP下的apps.py文件中. 首先执行每个APP下的admin.py 文件. def autodiscover(): autodisco ...
- 模拟Django的admin自定义stark组件
1.新建Django项目--新建app:app01和stark--在settings中配置app和数据库--在models.py中新建模型表--完成数据库迁移 2.在stark下的apps.py中: ...
- 模拟admin组件自己开发stark组件之自定义list_display,反向解析url
反向解析 在上一篇文章中,我们创建好了stark这个组件,一个应用一个表有四个默认的url,那么我们如何区别这些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 ...
- 关于模拟admin实现stark组件的知识点
一. url知识 还记得include分发么?里面的参数都可以有些什么? urlconf_module本质是返回的是模块路径对象 def include(arg, namespace=None, ap ...
随机推荐
- Nginx代理proxy pass配置去除前缀
使用Nginx做代理的时候,可以简单的直接把请求原封不动的转发给下一个服务. 比如,访问abc.com/appv2/a/b.html, 要求转发到localhost:8088/appv2/a/b.ht ...
- Eclipse复制项目彻底修改项目名称
一.需求 需要新做一个项目,框架还是Maven+SSM,于是就把原来的项目copy了一个,操作是直接选中原项目,CTRL+C ,然后粘贴,这个时候会让你选择工作空间和给一个新的项目名字,如下图,输入新 ...
- nginx+awstats安装过程
awstats来来回回也装了好多遍了,每次都是现装现查,隐约的记得整个配置比较麻烦,中间有几个需要特别注意的地方,又记不得那些需要特殊对待,只能边找资料边回忆,最终还是搞出来了,在此分享给大家. 首先 ...
- 微软补丁安装工具wusa报错。
命令行需要msu格式的补丁安装文件的全路径,否则报错.
- Oracle NID工具修改数据库DBID、数据库名称、数据库实例名
DBID是数据库的唯一标识符,在一些特殊场合会涉及到DBID的相关内容,本篇文章的目的是演示将DB_NAME的值从ORCL修改为ORCL1. 一.查看当前的环境 [oracle@oracledb ad ...
- Vivado开发工具熟悉之工具使用杂记
这两天基本完成了实验室工程从ISE向vivado的移植,包括了两片FPGA的两个工程,这两个工程还算是比较大的工程,包括了内存,接口,embedded system,算法模块等,在这过程中也很好的熟悉 ...
- [svc]find+xargs/sed&sed后向引用+awk多匹配符+过滤行绝招总结&&产生随机数
30天内的文件打包 find ./test_log -type f -mtime -30|xargs tar -cvf test_log.tar.gz find,文件+超过7天+超过1M的+按日期为文 ...
- 《深入应用C++11:代码优化与工程级应用》勘误表
<深入应用C++11:代码优化与工程级应用>勘误表,会不断更新,欢迎读者留言或发邮件(cpp11book@163.com)给我提出宝贵意见. 1.第7.3节目录final和override ...
- 【XMPP】XMPP协议之原理篇
XMPP协议简介 XMPP协议(Extensible Messaging and Presence Protocol,可扩展消息处理现场协议)是一种基于XML的协议. 目的是为了解决及时通信标准而提出 ...
- Java多线程系列——线程池简介
什么是线程池? 为了避免系统频繁地创建和销毁线程,我们可以让创建的线程进行复用.用线程时从线程池中获取,用完以后不销毁线程,而是归还给线程池. JDK 对线程池的支持 为了更好的控制多线程,JDK 提 ...