溫馨提示×

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

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

django admin組件使用方法詳解

發(fā)布時(shí)間:2020-09-06 09:32:19 來(lái)源:腳本之家 閱讀:232 作者:一路向北_聽風(fēng) 欄目:開發(fā)技術(shù)

關(guān)于admin:

(1) admin的概述:

admin是一個(gè)django子代的組件,當(dāng)創(chuàng)建一個(gè)項(xiàng)目會(huì)后,就會(huì)在settings文件的 INSTALLED_APPS 中自動(dòng)注冊(cè),另外在urls.py 文件中同樣存在admin的路由

INSTALLED_APPS = [
 #自帶并且注冊(cè)的一個(gè)組件即app
  'django.contrib.admin',
  'django.contrib.auth',
  'django.contrib.contenttypes',
urlpatterns = [
  # 自動(dòng)存在的admin路由
  url(r'^admin/', admin.site.urls),
  url(r'^stark/', site.urls),

]

(2) admin 的執(zhí)行流程

當(dāng)django程序加載的時(shí)候,自動(dòng)循環(huán)加載已經(jīng)注冊(cè)的APP中的admin.py文件然后執(zhí)行

#在admin.py文件中有一個(gè)__init__文件 ,其中有代碼如下
#意思是:程序的啟動(dòng)自動(dòng)尋找名為admin的py文件,然后執(zhí)行
def autodiscover():
  autodiscover_modules('admin', register_to=site)
#具體的方法如下:
def autodiscover_modules(*args, **kwargs):
  """
  Auto-discover INSTALLED_APPS modules and fail silently when
  not present. This forces an import on them to register any admin bits they
  may want.

  You may provide a register_to keyword parameter as a way to access a
  registry. This register_to object must have a _registry instance variable
  to access it.
  """

執(zhí)行admin.py文件中的內(nèi)容

# 在django啟動(dòng)時(shí)候,系統(tǒng)自動(dòng)加載
from django.contrib import admin
#導(dǎo)入該APP下的models
from DRF import models
#此處是一個(gè)單例模式 admion.site 
admin.site.register(models.Publisher)

單例模式site 這里應(yīng)用的是一個(gè)單例模式,對(duì)于AdminSite類的一個(gè)單例模式,執(zhí)行的每一個(gè)App中的每一個(gè)admin.site都是一個(gè)對(duì)象

# AdminSite 類
class AdminSite(object):
    ...  
    def __init__(self, name='admin'):
      self._registry = {} # model_class class -> admin_class instance
      self.name = name
      self._actions = {'delete_selected': actions.delete_selected}
      self._global_actions = self._actions.copy()
      all_sites.add(self)
    ....
site = AdminSite()

執(zhí)行register方法

# AdminSite中的register 方法
  def register(self, model_or_iterable, admin_class=None, **options):
    """
    Registers the given model(s) with the given admin class.
    The model(s) should be Model classes, not instances.
    If an admin class isn't given, it will use ModelAdmin (the default
    admin options). If keyword arguments are given -- e.g., list_display --
    they'll be applied as options to the admin class.
    If a model is already registered, this will raise AlreadyRegistered.
    If a model is abstract, this will raise ImproperlyConfigured.
    """

知識(shí)補(bǔ)充: 單例模式

a.py

class AdminSite(object):

  def __init__(self):
    self._registry = {}
obj1 = AdminSite()

b.py

import a
a.obj1._registry['k2'] = 666

c.py

import a
a.obj1._registry['k1'] = 123
print(a.obj1._registry)

單例模式的實(shí)現(xiàn)方法

1:使用模塊

Python的模塊就是天然的單例模式。

因?yàn)槟K在第一次導(dǎo)入時(shí),會(huì)生成 .pyc 文件,當(dāng)?shù)诙螌?dǎo)入時(shí),就會(huì)直接加載 .pyc 文件,而不會(huì)再次執(zhí)行模塊代碼。

因此,我們只需把相關(guān)的函數(shù)和數(shù)據(jù)定義在一個(gè)模塊中,就可以獲得一個(gè)單例對(duì)象了。

例如:

class V1(object):
  def foo(self)
    pass
V1 = V1()

將上面代碼保存在文件test.py,要使用時(shí),直接在其他文件中導(dǎo)入此文件中的對(duì)象,這個(gè)對(duì)象既是單例模式的對(duì)象

如:from a import V1

2:使用裝飾器

def Singleton(cls):
  _instance = {}
  def _singleton(*args, **kargs):
    if cls not in _instance:
      _instance[cls] = cls(*args, **kargs)
    return _instance[cls]
  return _singleton
@Singleton
class A(object):
  a = 1
  def __init__(self, x=0):
    self.x = x
a1 = A(2)
a2 = A(3)

3:使用類

4:基于__new__方法實(shí)現(xiàn)

當(dāng)我們實(shí)例化一個(gè)對(duì)象時(shí),是先執(zhí)行了類的__new__方法

當(dāng):(我們沒寫時(shí),默認(rèn)調(diào)用object.__new__),實(shí)例化對(duì)象;然后再執(zhí)行類的__init__方法,對(duì)這個(gè)對(duì)象進(jìn)行初始化,所有我們可以基于這個(gè),實(shí)現(xiàn)單例模式

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

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

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

AI