Django 之ModelAdmin物件(補)

2022-10-05 18:01:17

一、後臺管理系統設定


1 在該表對應的models類裡面新增一個Meta類

class Meta:
    verbose_name_plural = '使用者表' # 指定該表在admin後臺的名字為: 使用者表
    # verbose_name = '使用者表'      # 末尾還是會自動加s

 

2 null=True,blank=True的區別

# null=True:  是告訴資料庫該欄位可以為空,admin後臺預設還是不允許為空
# blank=True: admin 後臺該欄位可以為空
phone = models.CharField(max_length = 11, blank = True, null = True, unique = True, verbose_name = "手機號")

 

3 settings.py設定,使django的後臺管理頁面變成中文、設定時區

# Internationalization
# https://docs.djangoproject.com/en/3.2/topics/i18n/

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

 

二、ModelAdmin 的常用屬性


1 登入檔

admin.py中只需要 Mode 中的某個類註冊,即可在 Admin 中實現增刪改查的功能。

from django.contrib import admin
from app import models
# Register your models here.

admin.site.register(models.UserInfo)
admin.site.register(models.Blog)

註冊完後點選表名即可修改表內容。

2 list_display 欄位展示

  • list_display:列表時,客製化顯示的列。
  • 在預設的情況下,Model 在 admin 列表修改頁(Admin ChangeList)只會顯示一列,內容是範例物件的__str__的返回值,如果想要多現實一些列的資料,就可以通過 list_display 屬性來實現。
  • 它除了可以設定 Model 的欄位名之外,還可以接收函數,且這個函數將一個 Model 範例物件作為引數,這個函數也需定義在 ModeAdmin 中。語法格式如下:list_display=[]
  • 在使用 list_display 時需要特別注意它的兩個特性
  • 對於 Foreignkey 型別的欄位,顯示的是 obj.__str__() 返回的值。
  • 不支援 ManyToManyField 型別的欄位,如果需要展示,可以用自定義方法實現。
# 方式一
class UserInfoAdmin(admin.ModelAdmin):
    list_display = ('username', 'email',)
admin.site.register(models.UserInfo, UserInfoAdmin)

# 方式二
@admin.register(models.UserInfo)                    
class UserInfoAdmin(admin.ModelAdmin):
    list_display = ('username', 'email',)

 

3 list_display_links 連結至列表頁面,可以點選跳轉。

  • 使用 list_display_links 可以控制 list_display 中的欄位是否應該連結到物件的「更改」頁面。預設情況下,更改列表頁面會只將第一列連結到每個專案的更改頁面。它的使用格式和 list_display 相同,是列表或者元組型別。

  • 同時它也可以指定一個或多個欄位。只要這些欄位在中 list_display 中存在 ,那麼 Django 就不會在意連結了多少個欄位。

注意:要使用 list_display_links 這個屬性 ,必須先要定義 list_display。

4 list_filter 過濾器

  • 設定 list_filter 屬性,可以在 Admin 後臺的列表修改頁的右側新增過濾器,且各個過濾條件是 and 的關係。
  • list_filter 是列表或者元組型別,通常使用它會傳遞兩類元素:一個是 Model 的欄位名,另一個是繼承自以下的類(並不常用):django.contrib.admin.SimpleListFilter
  • 對於 Model 的欄位名,欄位型別必須屬於 BooleanField、CharField、DateField、DateTimeField、IntegerField、ForeignKey 或 ManyToManyField 中的一種。
  • 同樣也可以使用雙下畫線實現跨表關聯。範例如下所示:list_filter= ['title', 'pub__pubname']

5  list_editable 設定欄位名稱

  • 允許模型的欄位在列表頁面上被編輯,也就是說,它包含的欄位將在 list_editable 更改頁面上顯示為表單視窗小部件,從而允許使用者一次編輯和儲存多行。

使用 list_editable 時,你應該注意以下規則: 

  • list_editable 列表中的每個欄位也必須位於 list_display 中。否則你將無法編輯;
  • 同一欄位不能同時在 list_editable 和 list_display_links 中顯示,因為同一欄位只能屬於它們兩者中的一個。

6 search_fileds 新增搜尋方塊

  • 在一些場景下給某些欄位新增搜尋方塊是很有意義的,Django 考慮到這一點提供了 search_fileds 屬性,在 Admin 中表現為一個搜尋方塊,查詢的欄位可以是 CharField 或TextField 型別的。
  • 也可以是對 ForeignKey 或 ManyToManyField 欄位型別的參照查詢,使用雙下畫線參照欄位名。使用範例如下:search_fields = ['blog__site_name']
  • 對於搜尋方塊中的輸入詞,Django 會將其分割成多個關鍵字,並返回所有包含這些關鍵字的範例物件。

提示:需要注意的是,每個關鍵字都必須是 search_fields 選項中的至少一個。

 

7 ordering

  • 列表時,資料排序規則
8 list_per_page
  • 列表分頁,顯示
9 date_hierarchy
  • 按時間分層 根據時間篩選表格
10 empty_value_display
  • 列資料為空時,顯示預設值
# 資料庫模型在: https://www.cnblogs.com/huaxiayuyi/p/16754258.html
class UserInfoAdmin(admin.ModelAdmin):
    # 排序
    # ordering = ('nid',)
    # 倒序
    ordering = ('-nid',) 
    # 顯示的欄位
    list_display = ('nid', 'email', 'create_time', 'phone', 'blog')
    # 點選可跳轉
    list_display_links = ( 'create_time',)
    # 過濾器
    list_filter = ('email', 'phone', 'blog__site_name')
    # 可編輯
    list_editable = ('email', )
    # 搜尋方塊
    search_fields = ['email', 'phone', 'blog__site_name']
    # 時間分層
    date_hierarchy = 'create_time'
    # 分頁
    list_per_page = 3
    # 為空時,顯示預設值
    empty_value_display = '-empty-'
    # 是否顯示選擇個數
    actions_selection_counter = True
    # Action選項都是在頁面上方顯示
    actions_on_top = False
    # Action選項都是在頁面下方顯示
    actions_on_bottom = True
    
admin.site.register(models.UserInfo, UserInfoAdmin)
admin.site.register(models.Blog)

 

 

11