上一章中我们所建项目只含有一个应用,当项目变得比较大,也就是应用变得多时,模板和静态文件等都需要放在指定的目录。
自定义模板位置
上一章中,我们有提到“模板目录必须是templates。默认情况下,搜索模版时,Django会在每个安装应用的子目录中搜索templates目录。”,其实,是否可以搜索每个应用子目录中templates目录,取决于settings.py中TEMPLATES的APP_DIRS的值,默认情况下,APP_DIRS的值为True(如下图),也就是说Django会在每个安装应用的子目录中搜索templates目录。
将APP_DIRS的值设为False,即不再允许Django按照默认方式寻找模板文件。
此时我们刷新网址http://127.0.0.1:8000/blog/,会出现以下TemplateDoesNotExist错误:
刷新网址http://127.0.0.1:8000/admin/,同样会出现TemplateDoesNotExist错误:
出现以上错误就是因为我们将APP_DIRS的值设为False了。解决上述问题的一种方案,就是将APP_DIRS的值设为True。这里我们采用另外一种方案:
我们注意到TEMPLATES中DIRS的值为空列表。这个DIRS是设置模板搜索路径的,所以我们可以将模板目录所在路径加入到DIRS的列表中。我们将DIRS的值更改为如下图所示,并将原来放在./blog/templates移动到./templates。
此时刷新页面,页面正常如下图所示,也就是说我们可以自定义模板目录和路径
自定义静态文件位置
所谓静态文件,就是网页中的CSS文件、Javascript文件以及网页上的的文件。
我们可以在settings.py看到Django对静态文件的定义
STATIC_URL = '/static/'是说可以通过URL访问静态文件,即每个应用可以在自己的目录下建立static目录,并将静态文件放入其中。这里我们采用与上边自定义模板类似的方式,把静态文件放到指定的目录中。在STATIC_URL = '/static/'下面增加如下图中的代码并在根目录下创建static目录
之所以能后这么设置,是因为Django的settings中的配置变量STATICFILES_FINDERS默认值规定了查找静态文件的顺序。
STATICFILES_FINDERS = ( 'django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder',)
在实际项目中,通常要将所有的静态文件放到同一个目录中,同时为了区分不同应用的静态文件,通常会在目录中再建立各个应用的子目录。