一个python项目下面可以建立多个APP,每个APP里面都可以建立templates目录用于存放模板文件,而且APP外面还有一个公用模板存放的目录templates。

一、公共模板下的templates

  1. TEMPLATES = [
  2. {
  3. 'BACKEND': 'django.template.backends.django.DjangoTemplates', # 定义模板引擎
  4. # 'DIRS': [BASE_DIR + '/apps/my_app/templates'],
  5. # 'DIRS': [BASE_DIR + '/apps/vote/templates'],
  6. 'DIRS': [os.path.join(BASE_DIR, 'apps/develop/templates')],
  7. #'DIRS': ['frontend/dist'], # 设置模板所在路径
  8. 'APP_DIRS': True, # 是否在APP里查找模板文件
  9. 'OPTIONS': {
  10. 'context_processors': [
  11. 'django.template.context_processors.debug',
  12. 'django.template.context_processors.request',
  13. 'django.contrib.auth.context_processors.auth',
  14. 'django.contrib.messages.context_processors.messages',
  15. ],
  16. },
  17. },
  18. ]

‘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” 子目录。

  1. class DjangoTemplates(BaseEngine):
  2. app_dirname = 'templates'
  3. def __init__(self, params):
  4. params = params.copy()
  5. options = params.pop('OPTIONS').copy()
  6. options.setdefault('autoescape', True)
  7. options.setdefault('debug', settings.DEBUG)
  8. options.setdefault('file_charset', settings.FILE_CHARSET)
  9. libraries = options.get('libraries', {})
  10. options['libraries'] = self.get_templatetag_libraries(libraries)
  11. super().__init__(params)
  12. self.engine = Engine(self.dirs, self.app_dirs, **options)

Django中关于templates的配置 - 图1

二、公用模板和APP内专用模板的加载顺序。

当APP内的view.py要渲染一个模板时,先根据模板名称去公用模板中查找,如果找到则完成渲染;
如果找不到则再去当前APP下的templates目录中查找;
即先公用,再专用。

参考文献

https://www.cnblogs.com/chushujin/p/12573119.html