5.怎么给Django-admin添加图标
UMSRA 的领导现喜欢你到目前创建的admin,但是市场营销人员希望你在所有的admin页面添加UMSRA logo图标
你需要在django settings重写django提供的默认templates django设置TEMPLATES的代码像这样:
TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [],'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',],},},]
这意味着Django将在每个应用程序内的名为template的目录中查找模板,
但是你可以通过重写TEMPLATES.DIRS 的值,
我可以把'DIRS': []转换成'DIRS': [os.path.join(BASE_DIR, 'templates/')],
并且创建一个templaes文件夹。 如果你的STATICFILE_DIRS是空的话,就设置:
STATICFILES_DIRS = [os.path.join(BASE_DIR, "static"),]
现在从admin app 里面拷贝base_site.html到你刚刚创建的templates\admin文件夹下,替换默认的品牌标记块
<h1 id="site-name"><a href="{% url 'admin:index' %}"><img src="{% static 'umsra_logo.png' %}" height="40px" /></a></h1>
改变你的base_site.html之后,将会像这样:
{% extends "admin/base.html" %}{% load staticfiles %}{% block title %}{{ title }} | {{ site_title|default:_('Django site admin') }}{% endblock %}{% block branding %}<h1 id="site-name"><a href="{% url 'admin:index' %}"><img src="{% static 'umsra_logo.png' %}" height="40px" /></a></h1>{% endblock %}{% block nav-global %}{% endblock %}
你的admin会像这样:

