Django中apps.py的目的是什么?

时间:2016-06-28 11:37:46

标签: python django

  

之前已经提出过这个问题: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中这是一个有效的假设/参数/约定吗?

1 个答案:

答案 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_configBlogConfig,但使用该应用的项目也可以选择CustomizableDateFormatBlogConfigI18nBlogConfig

然而,这使得可定制的应用程序非常糟糕。在上面的示例中,如果您想让应用用户同时使用CustomizableDateFormatBlogConfigI18nBlogConfig,则需要执行以下操作:

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中。