自定义管理页面的外观和感受
很清楚,每个管理页面的顶部都有Django administration
这个页面,这个很荒唐。使用Django的模版系统很容易改变。
自定义你的工程模版
在你的工程目录下创建一个templates
目录。模版可以放在Django能够获得文件系统的任何地方。但是,让你的模版放在工程的目录下是一个很好的遵循约定。
打开你的设置文件(mysite/setting.py
),在TEMPLATES
设置中添加一个DIRS
选项。
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR,'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
DIRS
是一系列文件系统目录,在加载Django文件模版的时候会被检查,它是一个搜索路径。
现在在templates
目录下创建一个叫admin
的目录,并将默认的Django管理模版目录下的模版admin/base_site.html
。模版文件是在django/contrib/admin/templates
注意:如何寻找到Django的源文件:
$python
import sys
sys.path =sys.path[1:]
import django
print(django.__path__)
然后,只需编辑这个文件,用你自己网站的名字来替换下面的内容:{{ site_title|default:_('Hello,World') }}
。你应当以这样的代码来结束一部分代码:
{% block branding %}
<h1 id="site-name"><a href="{% url 'admin:index' %}">{{ site_header|default:_('Hello,World') }}</a></h1>
{% endblock %}
我们通过这种途径来教你如何重写模版。在一个实际的工程中,你可能要使用django.contrib.admin.AdminSite.site_header
属性来更容易地进行自定义。
这个模版包含了许多类似于{% block branding %}
和{{ title }}
的文本。{%
和{{
标签是Django模版语言的一部分。当Django渲染admin/base_site.html
时,这种模版语言会重构来产生最终的HTML网页。如果你现在还不清楚模版,不要担心,我们会在以后深入讲解Django模版语言的。
自定义你的应用模版
机敏的读者可能会问:如果DIRS
是空的,那么Django如何发现默认的管理者模版呢?答案是,因为APP_DIRS
被设置为True
,Django会自动寻找每个应用包中的templates/
子目录。