标题:django后台全面汉化 | 作者: catfish | 时间:2019年12月06日
暂无法显示图片

目录

  • 1. 设置语言和时区
  • 2. 汉化数据表中的数据结构
  • 3. 汉化app名称
  • 4. 修改后台标题

聊聊

这则笔记来自于https://www.bilibili.com/video/av52325224

设置语言和时区

# settings.py
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'

汉化数据表中的数据结构

汉化字段

通过设置verbose_name属性来汉化字段

# eg:
title = models.CharField(max_length, verbose_name="标题")

汉化表中带返回值的函数

通过short_description属性来汉化字段

# models.py or admin.py
def nickname(self):
    return self.title
nickname.short_description = '昵称'   # 通过这个属性赋值来指定函数名汉化

汉化表名

# models.py
class Meta:
    verbose_name = "博客"
    verbose_name_plural = verbose_name     # 如果不设置这条表名后会带有's'符号

总览

上面是部分代码,这个是以上内容的总揽,以models.py为例:

# models.py
from django.db import models

class Blog(models.Model):
    title = models.CharField(max_length=255,verbose_name="标题")

    def nickname(self):
        return self.title
    nickname.short_description = "昵称"

    class Meta:
        verbose_name="博客"
        verbose_name_plural = verbose_name

汉化app名称

1,加上verbose_name

# app.py
from django.apps import AppConfig

class BlogConfig(AppConfig):
    name = 'blog'
    verbose_name="我的网站"    # 加上verbose_name,上面的都是默认标配

2,在__init__文件中启用这个app:

# __init__.py
default_app_config = "blog.apps.BlogConfig"   # 指向app内的类

3,大功告成。

修改后台标题

原理:覆盖admin模板文件来自定义管理员外观。

关于模板文件:模板文件会先找项目中配置的模板文件位置,再找app内的模板文件。由于app内模板文件关联较紧的缘故,第三方模块一般会把模块放到app内给其他人使用。

开始

运行该命令来找到文件的位置(按照我的返回值接着说下去):

$ python3 -c "import django;print(django.__path__)"
['/home/catfish/local/lib/python3.6/site-packages/Django']

然后进入这个目录:

cd /home/catfish/.local/lib/python3.6/site-packages/django

觉得到了?不,才刚开始。再进入:

cd contrib/admin/templates/admin

然后把这个文件夹下面的base_site.html文件复制出来,放的位置为:你的项目配置设定的templates文件/admin/base_site.html。然后可以修改它的名称了。

这个项目的文件内容如下所示:

<!-- base_site.html -->
{% extends "admin/base.html" %}

{% block title %}{{ title }} | {{ site_title|default:_('Django site admin') }}{% endblock %}

{% block branding %}
<h1 id="site-name"><a href="{% url 'admin:index' %}">{{ site_header|default:_('Django administration') }}</a></h1>
{% endblock %}

{% block nav-global %}{% endblock %}

然后修改a标签内的东西即可,比如我修改的:

<!-- base_site.html -->
{% extends "admin/base.html" %}

{% block title %}后台禁地,请勿造次{% endblock %}

{% block branding %}
<h1 id="site-name"><a href="{% url 'admin:index' %}">普通用户与狗不得入内</a></h1>
{% endblock %}

{% block nav-global %}{% endblock %}

然后我的后台效果:

突发奇想。用上面的方法还可以把base.py拿出来给后台的网页搞个装修!搞好了记得分享给我看啊!

我要评论

没有登录?请先登录后再评论

最新评论

暂无人评论,来抢个沙发吧!