Django后台全面汉化技巧详解(第三方app也管用):

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

设置语言和时区

# 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):
   default_auto_field = 'django.db.models.BigAutoField'
    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 %}

以上就是经验总结,码字不易请点个赞,收藏!

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超翔之逸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值