django之中間件、緩存、信號、admin內置後臺

目錄:html

  • 中間件
  • 緩存
  • 信號
  • admin後臺

1、中間件

一、什麼是中間件?python

  • 中間件是一個、一個的管道,若是相對任何全部的經過Django的請求進行管理都須要自定義中間件數據庫

  • 中間件能夠對進來的請求和出去的請求進行控制django

  • 中間件是一類。緩存

由上圖可知,中間件是位於wsgi和路由系統中間的環節。用戶請求和和迴應請求都會通過中間件。session

看下面的代碼在settings裏中間件的類:app

 1 MIDDLEWARE_CLASSES = [
 2     'django.middleware.security.SecurityMiddleware',
 3     'django.contrib.sessions.middleware.SessionMiddleware',
 4     'django.middleware.common.CommonMiddleware',
 5     'django.middleware.csrf.CsrfViewMiddleware',
 6     'django.contrib.auth.middleware.AuthenticationMiddleware',
 7     'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
 8     'django.contrib.messages.middleware.MessageMiddleware',
 9     'django.middleware.clickjacking.XFrameOptionsMiddleware',
10 ]
View Code

當有請求過來的時候,默認從上倒下執行!而後在返回的時候從下面在返回回去框架

二、自定義中間件ide

中間件中能夠定義五個方法,分別是:memcached

  • process_request(self,request)
  • process_view(self, request, callback, callback_args, callback_kwargs)
  • process_exception(self, request, exception) 這個方法只有在出現錯誤的時候纔會觸發
  • process_response(self, request, response)
  • process_template_response(self,request,response) 這個方法只有在返回對象中有render方法的時候才執行,如render_to_response('/index/')

以上方法的返回值能夠是None和HttpResonse對象,若是是None,則繼續按照django定義的規則向下執行,若是是HttpResonse對象,則直接將該對象返回給用戶。

  • 建立中間件腳本

在django的的project目錄下建立一個middleware目錄,並建立一個md.py的腳本,內容以下:

 1 class Testmiddle:
 2     def process_request(self,request):
 3         print 'Testmiddle process_request'
 4     def process_view(self, request, callback, callback_args, callback_kwargs):
 5         print 'Testmiddle process_view'
 6     def process_exception(self, request, exception):
 7         pass
 8     def process_response(self, request, response):
 9         print 'Testmiddle process_response'
10         return response
11     
12 class Nextmiddle:
13     def process_request(self,request):
14         print 'Nextmiddle process_request'
15     def process_view(self, request, callback, callback_args, callback_kwargs):
16         print 'Nextmiddle process_view'
17     def process_exception(self, request, exception):
18         pass
19     def process_response(self, request, response):
20         print 'Nextmiddle process_response'
21         return response
  • 註冊中間件

修改settings.py文件,在MIDDLEWARE_CLASSES中添加咱們建立的中間件

 1 MIDDLEWARE_CLASSES = [
 2     'django.middleware.security.SecurityMiddleware',
 3     'django.contrib.sessions.middleware.SessionMiddleware',
 4     'django.middleware.common.CommonMiddleware',
 5     'django.middleware.csrf.CsrfViewMiddleware',
 6     'django.contrib.auth.middleware.AuthenticationMiddleware',
 7     'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
 8     'django.contrib.messages.middleware.MessageMiddleware',
 9     'django.middleware.clickjacking.XFrameOptionsMiddleware',
10     'middleware.middle.Testmiddle',
11     'middleware.middle.Nextmiddle',
12 ]
  • 設置url 略
  • 測試:
1 Testmiddle process_request
2 Nextmiddle process_request
3 Testmiddle process_view
4 Nextmiddle process_view
5 This app01 Views.index
6 Nextmiddle process_response
7 Testmiddle process_response

從輸出結果能夠看出:

他是先執行Testmiddle 的request 方法又執行了Nextmiddle的 process_request方法, 而後在執行Testmiddle的view方法,Nextmiddle的view方法

注意:django版本1.10之後,會報以下錯誤:

解決以下:

 1 from django.utils.deprecation import MiddlewareMixin
 2 class Testmiddle(MiddlewareMixin):
 3     def process_request(self,request):
 4         print 'Testmiddle process_request'
 5     def process_view(self, request, callback, callback_args, callback_kwargs):
 6         print 'Testmiddle process_view'
 7     def process_exception(self, request, exception):
 8         pass
 9     def process_response(self, request, response):
10         print 'Testmiddle process_response'
11         return response
12     
13 class Nextmiddle(MiddlewareMixin):
14     def process_request(self,request):
15         print 'Nextmiddle process_request'
16     def process_view(self, request, callback, callback_args, callback_kwargs):
17         print 'Nextmiddle process_view'
18     def process_exception(self, request, exception):
19         pass
20     def process_response(self, request, response):
21         print 'Nextmiddle process_response'
22         return response
View Code

注意:
* 老版本中在中間件中若是某個中間件類的方法返回的不是none,則後面的中間件不會再處理請求,也不會到達路由系統,而是直接到第一個process_response,開始全部的process_response處理
* 新版本中在中間件中若是某個中間件類的方法返回的不是none,則後面的中間件不會再處理請求,也不會到達路由系統,而是直接到最後一個process_response處理,而後返回給客戶端

2、緩存

因爲Django是動態網站,全部每次請求均會去數據進行相應的操做,當程序訪問量大時,耗時必然會更加明顯,最簡單解決方式是使用:緩存,緩存將一個某個views的返回值保存至內存或者memcache中,5分鐘內再有人來訪問時,則再也不去執行view中的操做,而是直接從內存或者Redis中以前緩存的內容拿到,並返回。

Django中提供了6種緩存方式:

  • 開發調試
  • 內存
  • 文件
  • 數據庫
  • Memcache緩存(python-memcached模塊)
  • Memcache緩存(pylibmc模塊)

一、開發調試

 1 # 此爲開始調試用,實際內部不作任何操做
 2     # 配置:
 3         CACHES = {
 4             'default': {
 5                 'BACKEND': 'django.core.cache.backends.dummy.DummyCache',     # 引擎
 6                 'TIMEOUT': 300,                                               # 緩存超時時間(默認300,None表示永不過時,0表示當即過時)
 7                 'OPTIONS':{
 8                     'MAX_ENTRIES': 300,                                       # 最大緩存個數(默認300)
 9                     'CULL_FREQUENCY': 3,                                      # 緩存到達最大個數以後,剔除緩存個數的比例,即:1/CULL_FREQUENCY(默認3)
10                 },
11                 'KEY_PREFIX': '',                                             # 緩存key的前綴(默認空)
12                 'VERSION': 1,                                                 # 緩存key的版本(默認1)
13                 'KEY_FUNCTION' 函數名                                          # 生成key的函數(默認函數會生成爲:【前綴:版本:key】)
14             }
15         }
16 
17 
18     # 自定義key
19     def default_key_func(key, key_prefix, version):
20         """
21         Default function to generate keys.
22 
23         Constructs the key used by all other methods. By default it prepends
24         the `key_prefix'. KEY_FUNCTION can be used to specify an alternate
25         function with custom key making behavior.
26         """
27         return '%s:%s:%s' % (key_prefix, version, key)
28 
29     def get_key_func(key_func):
30         """
31         Function to decide which key function to use.
32 
33         Defaults to ``default_key_func``.
34         """
35         if key_func is not None:
36             if callable(key_func):
37                 return key_func
38             else:
39                 return import_string(key_func)
40         return default_key_func
View Code

二、內存

 1 # 此緩存將內容保存至內存的變量中
 2     # 配置:
 3         CACHES = {
 4             'default': {
 5                 'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
 6                 'LOCATION': 'unique-snowflake',
 7             }
 8         }
 9 
10     # 注:其餘配置同開發調試版本
View Code

三、文件

 1 # 此緩存將內容保存至文件
 2     # 配置:
 3 
 4         CACHES = {
 5             'default': {
 6                 'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
 7                 'LOCATION': '/var/tmp/django_cache',
 8             }
 9         }
10     # 注:其餘配置同開發調試版本
View Code

四、數據庫

 1     # 此緩存將內容保存至數據庫
 2 
 3     # 配置:
 4         CACHES = {
 5             'default': {
 6                 'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
 7                 'LOCATION': 'my_cache_table', # 數據庫表
 8             }
 9         }
10 
11     # 注:執行建立表命令 python manage.py createcachetable
View Code

五、Memcach緩存(python-memcached模塊)

 1 # 此緩存使用python-memcached模塊鏈接memcache
 2 
 3     CACHES = {
 4         'default': {
 5             'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
 6             'LOCATION': '127.0.0.1:11211',
 7         }
 8     }
 9 
10     CACHES = {
11         'default': {
12             'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
13             'LOCATION': 'unix:/tmp/memcached.sock',
14         }
15     }   
16 
17     CACHES = {
18         'default': {
19             'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
20             'LOCATION': [
21                 '172.19.26.240:11211',
22                 '172.19.26.242:11211',
23             ]
24         }
25     }
View Code

六、Memcache緩存(pylibmc模塊)

 1 # 此緩存使用pylibmc模塊鏈接memcache
 2     
 3     CACHES = {
 4         'default': {
 5             'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
 6             'LOCATION': '127.0.0.1:11211',
 7         }
 8     }
 9 
10     CACHES = {
11         'default': {
12             'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
13             'LOCATION': '/tmp/memcached.sock',
14         }
15     }   
16 
17     CACHES = {
18         'default': {
19             'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
20             'LOCATION': [
21                 '172.19.26.240:11211',
22                 '172.19.26.242:11211',
23             ]
24         }
25     }
View Code

七、應用方式:

  • 全站使用
使用中間件,通過一系列的認證等操做,若是內容在緩存中存在,則使用FetchFromCacheMiddleware獲取內容並返回給用戶,當返回給用戶以前,判斷緩存中是否已經存在,若是不存在則UpdateCacheMiddleware會將緩存保存至緩存,從而實現全站緩存
1 MIDDLEWARE = [
2         'django.middleware.cache.UpdateCacheMiddleware',
3         # 其餘中間件...
4         'django.middleware.cache.FetchFromCacheMiddleware',
5     ]
6 
7     CACHE_MIDDLEWARE_ALIAS = ""
8     CACHE_MIDDLEWARE_SECONDS = ""
9     CACHE_MIDDLEWARE_KEY_PREFIX = ""
View Code
  • 單獨視圖緩存
 1 方式一:
 2         from django.views.decorators.cache import cache_page
 3 
 4         @cache_page(60 * 15)
 5         def my_view(request):
 6             ...
 7 
 8 方式二:
 9         from django.views.decorators.cache import cache_page
10 
11         urlpatterns = [
12             url(r'^foo/([0-9]{1,2})/$', cache_page(60 * 15)(my_view)),
13         ]
View Code
  • 局部視圖緩存
1 a. 引入TemplateTag
2 
3         {% load cache %}
4 
5 b. 使用緩存
6 
7         {% cache 5000 緩存key %}
8             緩存內容
9         {% endcache %}
View Code

參考L:https://docs.djangoproject.com/en/1.9/topics/cache/

3、信號

Django中提供了「信號調度」,用於在框架執行操做時解耦。通俗來說,就是一些動做發生的時候,信號容許特定的發送者去提醒一些接受者。

一、django內置信號

 1 Model signals
 2     pre_init                    # django的modal執行其構造方法前,自動觸發
 3     post_init                   # django的modal執行其構造方法後,自動觸發
 4     pre_save                    # django的modal對象保存前,自動觸發
 5     post_save                   # django的modal對象保存後,自動觸發
 6     pre_delete                  # django的modal對象刪除前,自動觸發
 7     post_delete                 # django的modal對象刪除後,自動觸發
 8     m2m_changed                 # django的modal中使用m2m字段操做第三張表(add,remove,clear)先後,自動觸發
 9     class_prepared              # 程序啓動時,檢測已註冊的app中modal類,對於每個類,自動觸發
10 Management signals
11     pre_migrate                 # 執行migrate命令前,自動觸發
12     post_migrate                # 執行migrate命令後,自動觸發
13 Request/response signals
14     request_started             # 請求到來前,自動觸發
15     request_finished            # 請求結束後,自動觸發
16     got_request_exception       # 請求異常後,自動觸發
17 Test signals
18     setting_changed             # 使用test測試修改配置文件時,自動觸發
19     template_rendered           # 使用test測試渲染模板時,自動觸發
20 Database Wrappers
21     connection_created          # 建立數據庫鏈接時,自動觸發

二、對於Django內置的信號,僅需註冊指定信號,當程序執行相應操做時,自動觸發註冊函數:

 1 from django.core.signals import request_finished
 2 from django.core.signals import request_started
 3 from django.core.signals import got_request_exception
 4 
 5 from django.db.models.signals import class_prepared
 6 from django.db.models.signals import pre_init, post_init
 7 from django.db.models.signals import pre_save, post_save
 8 from django.db.models.signals import pre_delete, post_delete
 9 from django.db.models.signals import m2m_changed
10 from django.db.models.signals import pre_migrate, post_migrate
11 
12 from django.test.signals import setting_changed
13 from django.test.signals import template_rendered
14 
15 from django.db.backends.signals import connection_created
16 
17 
18 def callback(sender, **kwargs):
19     print("xxoo_callback")
20     print(sender,kwargs)
21 
22     xxoo.connect(callback)
23     # xxoo指上述導入的內容
24 from django.core.signals import request_finished
25 from django.dispatch import receiver
26 
27 @receiver(request_finished)
28 def my_callback(sender, **kwargs):
29     print("Request finished!")

三、django自定義信號

  • 定義信號
1 import django.dispatch
2 pizza_done = django.dispatch.Signal(providing_args=["toppings", "size"]
View Code
  • 註冊信號
1 def callback(sender, **kwargs):
2     print("callback")
3     print(sender,kwargs)
4  
5 pizza_done.connect(callback)
View Code
  • 觸發信號
1 from 路徑 import pizza_done
2  
3 pizza_done.send(sender='seven',toppings=123, size=456)
View Code

因爲內置信號的觸發者已經集成到Django中,因此其會自動調用,而對於自定義信號則須要開發者在任意位置觸發。

參考L:https://docs.djangoproject.com/en/dev/topics/signals/

4、admin後臺

一、admin簡介:

Django內置的Admin是對於model中對應的數據表進行增刪改查提供的組件,使用方式有:

依賴APP:
        django.contrib.auth
        django.contrib.contenttypes
        django.contrib.messages
        django.contrib.sessions

    模板的context_processors:
        django.contrib.auth.context_processors.auth
        django.contrib.messages.context_processors.messages

    中間件:
        django.contrib.auth.middleware.AuthenticationMiddleware 
        django.contrib.messages.middleware.MessageMiddleware
二、配置路由:
urlpatterns  =  [
         url(r '^admin/' , admin.site.urls),
     ]
三、當前配置的路由能夠建立一些路由映射關係:

/admin/
/admin/login/
/admin/logout/
/admin/password_change/
/admin/password_change/done/

/admin/app名稱/model名稱/
/admin/app名稱/model名稱/add/
/admin/app名稱/model名稱/ID值/history/
/admin/app名稱/model名稱/ID值/change/
/admin/app名稱/model名稱/ID值/delete/

四、定製Admin

在admin.py中只須要講Mode中的某個類註冊,便可在Admin中實現增刪改查的功能,如:

admin.site.register(models.UserInfo)

可是,這種方式比較簡單,若是想要進行更多的定製操做,須要利用ModelAdmin進行操做,如:

 1 方式一:
 2     class UserAdmin(admin.ModelAdmin):
 3         list_display = ('user', 'pwd',)
 4  
 5     admin.site.register(models.UserInfo, UserAdmin) # 第一個參數能夠是列表
 6      
 7  
 8 方式二:
 9     @admin.register(models.UserInfo)                # 第一個參數能夠是列表
10     class UserAdmin(admin.ModelAdmin):
11         list_display = ('user', 'pwd',)

ModelAdmin中提供了大量的可定製功能,如

  • list_display,列表時,定製顯示的列。
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     list_display = ('user', 'pwd', 'xxxxx')
4  
5     def xxxxx(self, obj):
6         return "xxxxx"
View Code
  • list_display_links,列表時,定製列能夠點擊跳轉。
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     list_display = ('user', 'pwd', 'xxxxx')
4     list_display_links = ('pwd',)
View Code
  • list_filter,列表時,定製右側快速篩選。
 1 from django.utils.translation import ugettext_lazy as _
 2  
 3 @admin.register(models.UserInfo)
 4 class UserAdmin(admin.ModelAdmin):
 5     list_display = ('user', 'pwd')
 6  
 7     class Ugg(admin.SimpleListFilter):
 8         title = _('decade born')
 9         parameter_name = 'xxxxxx'
10  
11         def lookups(self, request, model_admin):
12             """
13             顯示篩選選項
14             :param request:
15             :param model_admin:
16             :return:
17             """
18             return models.UserGroup.objects.values_list('id', 'title')
19  
20         def queryset(self, request, queryset):
21             """
22             點擊查詢時,進行篩選
23             :param request:
24             :param queryset:
25             :return:
26             """
27             v = self.value()
28             return queryset.filter(ug=v)
29  
30     list_filter = ('user',Ugg,)
View Code
  • list_select_related,列表時,連表查詢是否自動select_related
  • 分頁相關
1 # 分頁,每頁顯示條數
2     list_per_page = 100
3  
4 # 分頁,顯示所有(真實數據<該值時,纔會有顯示所有)
5     list_max_show_all = 200
6  
7 # 分頁插件
8     paginator = Paginator
View Code
  •  list_editable,列表時,能夠編輯的列
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     list_display = ('user', 'pwd','ug',)
4     list_editable = ('ug',)
View Code
  • search_fields,列表時,模糊搜索的功能
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3      
4     search_fields = ('user', 'pwd')
View Code
  • date_hierarchy,列表時,對Date和DateTime類型進行搜索
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3  
4     date_hierarchy = 'ctime'
View Code
  • preserve_filters,詳細頁面,刪除、修改,更新後跳轉回列表後,是否保留原搜索條件
  • ave_as = False,詳細頁面,按鈕爲「Sava as new」 或 「Sava and add another」
  • save_as_continue = True,點擊保存並繼續編輯
1 save_as_continue = True
2  
3 # 若是 save_as=True,save_as_continue = True, 點擊Sava as new 按鈕後繼續編輯。
4 # 若是 save_as=True,save_as_continue = False,點擊Sava as new 按鈕後返回列表。
5  
6 New in Django 1.10.
View Code
  • save_on_top = False,詳細頁面,在頁面上方是否也顯示保存刪除等按鈕
  • inlines,詳細頁面,若是有其餘表和當前表作FK,那麼詳細頁面能夠進行動態增長和刪除
1 class UserInfoInline(admin.StackedInline): # TabularInline
2     extra = 0
3     model = models.UserInfo
4  
5  
6 class GroupAdminMode(admin.ModelAdmin):
7     list_display = ('id', 'title',)
8     inlines = [UserInfoInline, ]
View Code
  • action,列表時,定製action中的操做
 1 @admin.register(models.UserInfo)
 2 class UserAdmin(admin.ModelAdmin):
 3  
 4     # 定製Action行爲具體方法
 5     def func(self, request, queryset):
 6         print(self, request, queryset)
 7         print(request.POST.getlist('_selected_action'))
 8  
 9     func.short_description = "中文顯示自定義Actions"
10     actions = [func, ]
11  
12     # Action選項都是在頁面上方顯示
13     actions_on_top = True
14     # Action選項都是在頁面下方顯示
15     actions_on_bottom = False
16  
17     # 是否顯示選擇個數
18     actions_selection_counter = True
View Code
  • 定製HTML模板
1 add_form_template = None
2 change_form_template = None
3 change_list_template = None
4 delete_confirmation_template = None
5 delete_selected_confirmation_template = None
6 object_history_template = None
View Code
  • raw_id_fields,詳細頁面,針對FK和M2M字段變成以Input框形式
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3  
4     raw_id_fields = ('FK字段', 'M2M字段',)
View Code
  • fields,詳細頁面時,顯示字段的字段
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     fields = ('user',)
View Code
  • exclude,詳細頁面時,排除的字段
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     exclude = ('user',)
View Code
  • readonly_fields,詳細頁面時,只讀字段
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     readonly_fields = ('user',)
View Code
  • fieldsets,詳細頁面時,使用fieldsets標籤對數據進行分割顯示
 1 @admin.register(models.UserInfo)
 2 class UserAdmin(admin.ModelAdmin):
 3     fieldsets = (
 4         ('基本數據', {
 5             'fields': ('user', 'pwd', 'ctime',)
 6         }),
 7         ('其餘', {
 8             'classes': ('collapse', 'wide', 'extrapretty'),  # 'collapse','wide', 'extrapretty'
 9             'fields': ('user', 'pwd'),
10         }),
11     )
View Code
  • 詳細頁面時,M2M顯示時,數據移動選擇(方向:上下和左右)
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     filter_vertical = ("m2m字段",) # 或filter_horizontal = ("m2m字段",)
View Code
  • ordering,列表時,數據排序規則
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     ordering = ('-id',)
4 5     def get_ordering(self, request):
6         return ['-id', ]
View Code
  • view_on_site,編輯時,是否在頁面上顯示view on set
1 view_on_site = False
2 3 def view_on_site(self, obj):
4     return 'https://www.baidu.com'
View Code
  • radio_fields,詳細頁面時,使用radio顯示選項(FK默認使用select)
1 radio_fields = {"ug": admin.VERTICAL} # 或admin.HORIZONTAL
View Code
  • show_full_result_count = True,列表時,模糊搜索後面顯示的數據個數樣式
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     # show_full_result_count = True # 1 result (12 total)
4     # show_full_result_count = False  # 1 result (Show all)
5     search_fields = ('user',)
View Code
  • formfield_overrides = {},詳細頁面時,指定現實插件
 1 from django.forms import widgets
 2 from django.utils.html import format_html
 3  
 4 class MyTextarea(widgets.Widget):
 5     def __init__(self, attrs=None):
 6         # Use slightly better defaults than HTML's 20x2 box
 7         default_attrs = {'cols': '40', 'rows': '10'}
 8         if attrs:
 9             default_attrs.update(attrs)
10         super(MyTextarea, self).__init__(default_attrs)
11  
12     def render(self, name, value, attrs=None):
13         if value is None:
14             value = ''
15         final_attrs = self.build_attrs(attrs, name=name)
16         return format_html('<textarea {}>\r\n{}</textarea>',final_attrs, value)
17  
18  
19  
20 @admin.register(models.UserInfo)
21 class UserAdmin(admin.ModelAdmin):
22  
23     formfield_overrides = {
24         models.models.CharField: {'widget': MyTextarea},
25     }
View Code
  • prepopulated_fields = {},添加頁面,當在某字段填入值後,自動會將值填充到指定字段。
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3  
4     prepopulated_fields = {"email": ("user","pwd",)}
View Code

PS: DjangoAdmin中使用js實現功能,頁面email字段的值會在輸入:user、pwd時自動填充

  • form = ModelForm,用於定製用戶請求時候表單驗證
 1 from app01 import models
 2 from django.forms import ModelForm
 3 from django.forms import fields
 4  
 5  
 6 class MyForm(ModelForm):
 7     others = fields.CharField()
 8  
 9     class Meta:
10         model = models = models.UserInfo
11         fields = "__all__"
12  
13 @admin.register(models.UserInfo)
14 class UserAdmin(admin.ModelAdmin):
15  
16     form = MyForm
View Code
  • empty_value_display = "列數據爲空時,顯示默認值"
1 @admin.register(models.UserInfo)
2 class UserAdmin(admin.ModelAdmin):
3     empty_value_display = "列數據爲空時,默認顯示"
4  
5     list_display = ('user','pwd','up')
6  
7     def up(self,obj):
8         return obj.user
9     up.empty_value_display = "指定列數據爲空時,默認顯示"
View Code
相關文章
相關標籤/搜索