一个python项目下面可以建立多个APP,每个APP里面都可以建立templates目录用于存放模板文件,而且APP外面还有一个公用模板存放的目录templates。
一、公共模板下的templates
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates', # 定义模板引擎
# 'DIRS': [BASE_DIR + '/apps/my_app/templates'],
# 'DIRS': [BASE_DIR + '/apps/vote/templates'],
'DIRS': [os.path.join(BASE_DIR, 'apps/develop/templates')],
#'DIRS': ['frontend/dist'], # 设置模板所在路径
'APP_DIRS': True, # 是否在APP里查找模板文件
'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',
],
},
},
]
'DIRS': [BASE_DIR + '/templates']为存放目录templates下面存放的是公用模板,此设置为APP下所有模板和公共模板共享共用
原因:
每个APP里面创建的templates目录下,存放该APP专用的模板,不需要在settings.py配置文件中明确指定APP下的模板目录。因为settings.py配置文件设置了DjangoTemplates后,并将APP_DIRS设置成了True;在DjangoTemplates模块中明确指出了app_dirname = 'templates';这将会让DjangoTemplates在每个INSTALLED_APPS文件夹中寻找 "templates" 子目录。
class DjangoTemplates(BaseEngine): app_dirname = 'templates' def __init__(self, params): params = params.copy() options = params.pop('OPTIONS').copy() options.setdefault('autoescape', True) options.setdefault('debug', settings.DEBUG) options.setdefault('file_charset', settings.FILE_CHARSET) libraries = options.get('libraries', {}) options['libraries'] = self.get_templatetag_libraries(libraries) super().__init__(params) self.engine = Engine(self.dirs, self.app_dirs, **options)
二、公用模板和APP内专用模板的加载顺序。
当APP内的view.py要渲染一个模板时,先根据模板名称去公用模板中查找,如果找到则完成渲染;
如果找不到则再去当前APP下的templates目录中查找;
即先公用,再专用。