码迷,mamicode.com
首页 > 其他好文 > 详细

Django-admin组件

时间:2018-08-29 01:14:19      阅读:203      评论:0      收藏:0      [点我收藏+]

标签:rop   not   elm   settings   ini   rtc   而且   site   list   

如何仿照admin实现一个自定义的增删改查的组件?

一、启动
    1、创建一个与Django项目无关的,可以单独分离出来用在多个项目上的名称为my_admin的app:
        python manage.py startapp my_admin    
    2、创建两个与Django项目有关的两个app:
        python manage.py startapp app01
        python manage.py startapp app02
    3、在settings.py中的INSTALLED_APPS变量中添加:
        app01.apps.App01Config,
        app02.apps.App02Config,
        my_admin.apps.MyAdminConfig,
    4、将my_admin、app01和app02中的admin.py文件全部删除,重新分别在app01和app02中添加myAdmin.py
    5、app01下models.py中添加Book,Publish,AuthorDetail,Author类
    6、app02下models.py中添加Food类
    7、迁移数据库:
        python manage.py makemigrations
        python manage.py migrate
    8、my_admin的app下有一个apps.py文件,在此文件中添加:
        from django.utils.module_loading import autodiscover_modules
        class MyAdminConfig(AppConfig):
            name = my_admin

            def ready(self):
                autodiscover_modules("myAdmin")
二、注册
    1、my_admin的app下创建一个python package的包,名称为service
    2、在service文件夹下新建一个sites.py文件
    3、sites.py中添加以下代码:
        class ModelMyAdmin():
            list_display = []
            
            def __init__(self,model):
                self.model = model
            
        
        class MyAdminSite():
            def __init__(self):
                self._registry = {}
                
            def register(self,model,my_admin_class = None):
                if not my_admin_class:
                    my_admin_class = ModelMyAdmin
                self._registry[model] = my_admin_class(model)
        
        
        site = MyAdminSite()
    4、在app01下的myAdmin.py中注册模型类:
        from my_admin.service.sites import ModelMyAdmin,site
        from app01.models import Book,Publish,Author,AuthorDetail
        
        class BookConfig(ModelMyAdmin):
            list_display = ["title","publish_date","price"]
            
            
        site.register(Book,BookConfig)
        site.register(Publish)
        site.register(Author)
        site.register(AuthorDetail)
        
        print("app01下的site._registry-->",site._registry)
        启动项目后,打印出此字典证明已经注册成功
        {
            <class app01.models.Author>: <my_admin.service.sites.ModelMyAdmin object at 0x0000000003EA70B8>, 
            <class app01.models.AuthorDetail>: <my_admin.service.sites.ModelMyAdmin object at 0x0000000003EB1B00>, 
            <class app01.models.Book>: <app01.myAdmin.BookConfig object at 0x0000000003EB1EB8>, 
            <class app01.models.Publish>: <my_admin.service.sites.ModelMyAdmin object at 0x0000000003EB1EF0>
        }
三、设计url
    1、在urls.py文件中:
        from django.conf.urls import url
        from my_admin.service.sites import site
        
        urlpatterns = [
            url(r^my_admin/,site.urls),
        ]
        
    2、在sites.py文件中的MyAdminSite类中继续添加一个urls方法:
        from django.conf.urls import url
        def get_urls_01(self):
            res = []
            for model,config_obj in self._registry.items():
                model_name = model._meta.model_name
                app_label = model._meta.app_label
                add_url = url(r{}/{}/.format(app_label,model_name),config_obj.urls)    #config_obj:某个model的配置类(自定义配置类或者默认配置类)对象     
                res.append(add_url)
            return res
        
        @property
        def urls(self):
            return self.get_urls_01(),None,None
            
    3、在sites.py文件中的ModelMyAdmin类中继续添加一个urls方法:
        from django.shortcuts import render
        def listview(self,request):
            print("self-->",self) # 当前访问模型类的配置类对象
            print("self.model-->",self.model) # 当前访问模型类
            
            data = self.model.objects.all()
            return render(request,"listview.html",{"data_list":data})    
            
        def addview(self,request):
            return HttpResponse("addview")

        def changeview(self,request, id):
            return HttpResponse("changeview")

        def deleteview(self,request, id):
            return HttpResponse("deleteview")    
            
        def get_urls_02(self):
            res = [
                url(r^$,self.listview)
                url(r^add/$,self.addview)
                url(r^(\d+)/change/$,self.changeview)
                url(r^(\d+)/delete/$,self.deleteview
            ]
            return res
        
        @property        
        def urls(self):
            return self.get_urls_02(),None,None
为什么要将get_urls_02的方法写入到ModelMyAdmin类中,而不写在MyAdminSite类中?
    将get_urls_02写入到MyAdminSite类中,由于单例模式造成返回的是同一个页面,如果是简单的返回一个HttpResponse对象,是可以的;
    但是现实需求是不同的表要展示不同的视图数据而且不同的表要有不同的配置信息,故需要写入在ModelMyAdmin类中。

 

Django-admin组件

标签:rop   not   elm   settings   ini   rtc   而且   site   list   

原文地址:https://www.cnblogs.com/yangqian007/p/9551710.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
分享档案
周排行
mamicode.com排行更多图片
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!