Django 静态自定义化配置

STATIC

# APP本地静态资源目录(就APP对应的)
STATIC_URL = "/static/"

# 远程静态文件URL(少用)
REMOTE_STATIC_URL

# 外部引用静态文件目录(外层的)
STATICFILES_DIRS = [os.path.join(BASE_DIR, "static")]

# collect本地静态文件目录(python manage.py collectstatic可以出现的)
STATIC_ROOT = os.path.join(BASE_DIR, "staticfiles")

TEMPLATES

一般 Django 默认的 TEMPLATES 配置为:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

        注:BACKEND: 指定模板引擎(一般不需改动)。APP_DIRS: 一个布尔值,指示是否在每个已安装的应用程序的 templates 子目录中查找模板。在这个例子中,它被设置为 True,这意味着 Django 会在每个应用程序的 templates 文件夹中查找模板;

        比如这时候你在外部引用了一个你自身开发的文件夹,在前后端不分离式的项目中,那么就需要塞到 DIRS 中,如果是配置前端的环境变量,那么直接塞到 OPTIONS 的 context_processors。

        如果你使用的是一些把 TEMPLATES 内嵌到SDK里的框架,那么可以直接用字典的方式赋值即可。

        

        比如你在你的 APP (这里叫 hh_app)写了一个context_processors.py文件

def set_global_variable(request):
    context = {
        "STATIC_URL": settings.STATIC_URL + "dist/",  # 本地静态文件访问
        "APP_ID": settings.APP_ID,  # app id
    }
    return context

配置文件配置以下即可:

TEMPLATES[0]["OPTIONS"]["context_processors"] += ("hh_app.context_processors.set_global_variable",)

猜你喜欢

转载自blog.csdn.net/lxd_max/article/details/133800457