您的位置:首页 > 移动开发

Django之第一个app<11>

2015-08-28 20:49 459 查看
自定义管理页面的外观和感受

很清楚,每个管理页面的顶部都有
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/
子目录。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: