Django 之ModelAdmin對象

一、後台管理系統配置


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
# //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
  • 列數據為空時,顯示默認值
# 資料庫模型在: //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)

 

 

5 list_select_related 列表時,連表查詢是否自動 select_related

Tags: