Django之第一个app<11>

自定义管理页面的外观和感受

很清楚,每个管理页面的顶部都有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/子目录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值