溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Django中的Admin管理工具具體用法

發(fā)布時(shí)間:2021-09-17 09:11:50 來源:億速云 閱讀:160 作者:chen 欄目:編程語言

這篇文章主要講解了“Django中的Admin管理工具具體用法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Django中的Admin管理工具具體用法”吧!

Django admin自動(dòng)管理工具是 django.contrib 的一部分,我們可以在項(xiàng)目的 settings.py文件的 INSTALLED_APPS設(shè)置中看到它,可以將它看成django本身自帶的一個(gè)app應(yīng)用程序。

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
)

django.contrib是一套龐大的功能集,它是Django基本代碼的組成部分。

管理工具

在項(xiàng)目的urls.py文件中添加url(r'^admin/' ,admin.site.urls),一般在生成項(xiàng)目時(shí)會(huì)自動(dòng)設(shè)置好,我們只需要去掉注釋就行。

from django.conf.urls import url
from django.contrib import admin
urlpatterns = [
    url(r'^admin/', admin.site.urls),
]

使用管理工具

啟動(dòng)開發(fā)服務(wù)器,然后在瀏覽器中訪問 http://127.0.0.1:8000/admin/,得到登陸界面,如下圖所示:

Django中的Admin管理工具具體用法

接著可以通過命令 python manage.py createsuperuser來創(chuàng)建超級用戶。

>> python manage.py createsuperuser

Username (leave blank to use 'root'): 用戶名
Email address: 郵箱
Password: 密碼
Password (again):  確認(rèn)密碼
Superuser created successfully.

創(chuàng)建好超級用戶之后我們可以在剛剛的那個(gè)登錄界面輸入用戶名和密碼,登錄成功后的界面如下所示:

Django中的Admin管理工具具體用法

為了讓 admin 界面管理某個(gè)數(shù)據(jù)模型,我們需要先注冊該數(shù)據(jù)模型到 admin。比如我們之前在TestApp中已經(jīng)創(chuàng)建了模型Test。修改TestApp/admin.py文件:

from django.contrib import admin
from TestApp.models import Test

# Register your models here.
admin.site.register(Test)

在網(wǎng)頁中刷新后即可看到TestApp數(shù)據(jù)表,如下圖:

Django中的Admin管理工具具體用法

復(fù)雜的后臺數(shù)據(jù)模型

我們的django頁面管理功能非常強(qiáng)大,完全有能力處理更加復(fù)雜的數(shù)據(jù)模型。

首先我們可以在TestApp/models.py文件中增加兩個(gè)表(數(shù)據(jù)模型):

from django.db import models

# Create your models here.
class Test(models.Model):
    name = models.CharField(max_length=20)

class Contact(models.Model):
    name = models.CharField(max_length=200)
    age = models.IntegerField(default=0)
    email = models.EmailField()
    def __unicode__(self):
        return self.name

class Tag(models.Model):
    contact = models.ForeignKey(Contact, on_delete=models.CASCADE, )
    name = models.CharField(max_length=50)
    def __unicode__(self):
        return self.name

上述兩個(gè)表中,Tag以Contact為外部鍵。一個(gè)Contact可以對應(yīng)多個(gè)Tag。

在TestApp/admin.py文件中注冊多個(gè)模型并顯示:

from django.contrib import admin
from TestApp.models import Test,Contact,Tag

# Register your models here.
admin.site.register([Test, Contact,Tag])

刷新管理頁面,顯示結(jié)果如下所示:

Django中的Admin管理工具具體用法

在以上管理工具我們就能進(jìn)行復(fù)雜模型操作。

自定義表單

我們可以自定義管理頁面,來取代默認(rèn)的頁面。比如上面的 “add” 頁面。我們想只顯示 name 和 email 部分。修改 TestApp/admin.py:

from django.contrib import admin
from TestApp.models import Test, Contact, Tag

# Register your models here.
class ContactAdmin(admin.ModelAdmin):
    fields = ('name', 'email')

admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])

以上代碼定義了一個(gè) ContactAdmin 類,用以說明管理頁面的顯示格式。其中fields 屬性定義了要顯示的字段。

由于該類對應(yīng)的是 Contact 數(shù)據(jù)模型,我們在注冊的時(shí)候,需要將它們一起注冊。顯示效果如下:

Django中的Admin管理工具具體用法

還可以將輸入欄分塊,每個(gè)欄也可以定義自己的格式。修改 TestApp/admin.py為:

from django.contrib import admin
from TestApp.models import Test, Contact, Tag

# Register your models here.
class ContactAdmin(admin.ModelAdmin):
    fieldsets = (
        ['Main', {
            'fields': ('name', 'email'),
        }],
        ['Advance', {
            'classes': ('collapse',),  # CSS
            'fields': ('age',),
        }]
    )

admin.site.register(Contact, ContactAdmin)
admin.site.register([Test, Tag])

上面的欄目分為了 Main 和 Advance 兩部分。classes 說明它所在的部分的 CSS 格式。這里讓 Advance 部分隱藏:

Django中的Admin管理工具具體用法

Advance 部分旁邊有一個(gè) Show 按鈕,用于展開,展開后可點(diǎn)擊 Hide 將其隱藏,如下圖所示:

Django中的Admin管理工具具體用法

內(nèi)聯(lián)(Inline)顯示

上面的 Contact 是 Tag 的外部鍵,所以有外部參考的關(guān)系。而在默認(rèn)的頁面顯示中,將兩者分離開來,無法體現(xiàn)出兩者的從屬關(guān)系。我們可以使用內(nèi)聯(lián)顯示,讓 Tag 附加在 Contact 的編輯頁面上顯示。

修改TestApp/admin.py:

from django.contrib import admin
from TestApp.models import Test, Contact, Tag

# Register your models here.
class TagInline(admin.TabularInline):
    model = Tag

class ContactAdmin(admin.ModelAdmin):
    inlines = [TagInline]  # Inline
    fieldsets = (
        ['Main', {
            'fields': ('name', 'email'),
        }],
        ['Advance', {
            'classes': ('collapse',),
            'fields': ('age',),
        }]

    )

admin.site.register(Contact, ContactAdmin)
admin.site.register([Test])

訪問頁面后的效果圖如下所示:

Django中的Admin管理工具具體用法

列表頁的顯示

我們也可以自定義Contact 的列表頁的顯示,比如在列表中顯示更多的欄目,只需要在 ContactAdmin 中增加 list_display 屬性:

from django.contrib import admin
from TestApp.models import Test, Contact, Tag

# Register your models here.
class TagInline(admin.TabularInline):
    model = Tag

class ContactAdmin(admin.ModelAdmin):
    list_display = ('name', 'age', 'email')  # list
    inlines = [TagInline]  # Inline
    fieldsets = (
        ['Main', {
            'fields': ('name', 'email'),
        }],
        ['Advance', {
            'classes': ('collapse',),
            'fields': ('age',),
        }]

    )

admin.site.register(Contact, ContactAdmin)
admin.site.register([Test])

刷新頁面后效果如圖所示:

Django中的Admin管理工具具體用法

搜索功能

搜索功能在管理大量記錄時(shí)非常有,我們可以使用 search_fields 為該列表頁增加搜索欄:

from django.contrib import admin
from TestApp.models import Test, Contact, Tag

# Register your models here.
class TagInline(admin.TabularInline):
    model = Tag

class ContactAdmin(admin.ModelAdmin):
    list_display = ('name', 'age', 'email')  # list
    search_fields = ('name',)
    inlines = [TagInline]  # Inline
    fieldsets = (
        ['Main', {
            'fields': ('name', 'email'),
        }],
        ['Advance', {
            'classes': ('collapse',),
            'fields': ('age',),
        }]

    )

admin.site.register(Contact, ContactAdmin)
admin.site.register([Test])

感謝各位的閱讀,以上就是“Django中的Admin管理工具具體用法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Django中的Admin管理工具具體用法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI