当你使用python manage.py startapp app01的命令创建了一个名为app01的新应用后,通常接下来要做的就是在settings.py里注册它,把它加到INSTALLED_APPS里去。你可以选择直接添加app名,还可以添加该app对应的配置AppConfig子类。到底哪种方式更好呢?
# settings.py 注册app
# 方式1:直接加入app名,
INSTALLED_APPS = [
'django.contrib.admin',
'app01',
]
# 方式2:直接加入app对应的AppConfig子类
INSTALLED_APPS = [
'django.contrib.admin',
'app01.apps.App01Config',
]
回答这个问题没有简易答案,一切还得从Django的AppConfig类说起。
配置信息和verbose_name - 你有的我也要
Django一个项目(project)由多个应用(app)组成,每个app的创建和注册体现了一个插拔的思想,即插即用。与project一样,每个app其实也有自己的配置信息,只是我们很少配置而已。项目的配置信息我们一般写在settings.py里,那么每个app对应的配置信息我们写在哪里? 答案是每个app目录下的apps.py里。与settings.py中以字符串形式配置相关信息不同,每个app的配置信息是通过继承Django的AppConfig类实现的。
在实际开发过程中,我们不需要编辑apps.py,给每个app手动添加配置信息,这是因为Django会根据app名生成默认的配置类。它继承了AppConfig类,里面只有name一个基本属性,如下所示:
#app01/apps.py
from django.apps import AppConfig
class App01Config(AppConfig):
name = 'app01'
但也有不少情况下我们需要给app添加额外配置信息。举个例子,我们在自定义模型(Models)时会给每个模型起个verbose_name(别名), 便于人阅读。同样的,我们也可以给app起个verbose_name, 这时我们就需要修改apps.py添加别名了。比如本例中app01这个名字可读性太差,我们最好给它起个别名,比如"用户管理",我们可以按如下修改代码:
#app01/apps.py
from django.apps import AppConfig
class App01Config(AppConfig):
na