之前已经提出过这个问题:What is the purpose of apps.py in Django 1.9?
应用程序配置对象存储应用程序的元数据。可以在AppConfig子类中配置某些属性。其他由Django设置并且是只读的。
但是,应用程序的元数据意味着什么?它仅限于那些AppConfig
metadata:name
, verbose_name
, path
, label
, module
, models_module
吗?
或者延伸超出预定义的元数据是否有意义,特别是对于特定于应用程序的元数据,例如在 blog
应用程序中,我们有日期格式配置,通常定义如下:< / p>
# File: settings.py
BLOG = {
'DATE_FORMAT': 'ddMMYYY',
}
按以下方式使用:
# File: blog/<...>.py
from django.conf import settings
date_format = settings.BLOG['DATE_FORMAT']
相反,我们可以将此配置移至blog/apps.py
BlogConfig
?
class BlogConfig(AppConfig):
name = 'blog'
verbose_name = 'Awesome Blog'
date_format = 'ddMMYYYY'
因此,在应用程序的整个代码中,date_format
正在被使用:
# File: blog/<...>.py
from django.apps import apps
date_format = apps.get_app_config('blog').date_format
我觉得settings.py
是项目设置,但不是应用程序设置。因此,将所有应用程序设置放在apps.py
然后settings.py
内是更多声音。那么,对于我来说,将应用程序配置放在apps.py
而不是settings.py
中这是一个有效的假设/参数/约定吗?
答案 0 :(得分:3)
每个django安装项目都是唯一的,而应用程序应该是可重用的。
如果您将自定义应用设置放在项目的settings.py
中,那么它们应该是可修改的,特别是如果您(或其他人)将此应用重新用于其他项目。
现在,如果您将这些自定义设置放在应用的apps.py
中,这意味着它们无法在每个项目的基础上进行修改。在这种情况下,没有理由将它们放在apps.py
而不是constants
子模块中。除非您想提供一组有限的可能配置:
class BlogConfig(AppConfig):
name = 'blog'
verbose_name = "Blog"
date_format = 'ddMMYYYY'
class CustomizableDateFormatBlogConfig(BlogConfig):
date_format = getattr(settings, 'BLOG_DATE_FORMAT', BlogConfig.date_format)
class I18nBlogConfig(BlogConfig)
verbose_name = _("Blog")
default_app_config
为BlogConfig
,但使用该应用的项目也可以选择CustomizableDateFormatBlogConfig
或I18nBlogConfig
。
然而,这使得可定制的应用程序非常糟糕。在上面的示例中,如果您想让应用用户同时使用CustomizableDateFormatBlogConfig
和I18nBlogConfig
,则需要执行以下操作:
class BlogConfig(AppConfig):
name = 'blog'
verbose_name = "Blog"
date_format = 'ddMMYYYY'
class CustomizableDateFormatMixin:
date_format = getattr(settings, 'BLOG_DATE_FORMAT', BlogConfig.date_format)
class I18nMixin:
verbose_name = _("Blog")
class CustomizableDateFormatBlogConfig(CustomizableDateFormatMixin, BlogConfig):
pass
class I18nBlogConfig(I18nMixin, BlogConfig):
pass
class I18nCustomizableDateFormatBlogConfig(I18nMixin, CustomizableDateFormatMixin, BlogConfig):
pass
因此,除了需要提供一组不同应用配置的特定情况之外,您最好将自定义应用设置放在项目settings.py
中。