
- # 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")
一般 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",)