Django学习教程之静态文件的调用详解


Posted in Python onMay 08, 2018

前言

静态文件是指 网站中的 js, css, 图片,视频等文件,本文主要给大家介绍了关于Django学习之静态文件调用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

方法如下

1.settings.py 静态文件相关示例代码及说明:

# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/
 
STATIC_URL = '/static/'
 
# 当运行 python manage.py collectstatic 的时候
# STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用apache等部署的时候更方便
STATIC_ROOT = os.path.join(BASE_DIR, 'collected_static')
 
# 其它 存放静态文件的文件夹,可以用来存放项目中公用的静态文件,里面不能包含 STATIC_ROOT
# 如果不想用 STATICFILES_DIRS 可以不用,都放在 app 里的 static 中也可以
STATICFILES_DIRS = (
 os.path.join(BASE_DIR, "common_static"),
 '/path/to/others/static/', # 用不到的时候可以不写这一行
)
 
# 这个是默认设置,Django 默认会在 STATICFILES_DIRS中的文件夹 和 各app下的static文件夹中找文件
# 注意有先后顺序,找到了就不再继续找了
STATICFILES_FINDERS = (
 "django.contrib.staticfiles.finders.FileSystemFinder",
 "django.contrib.staticfiles.finders.AppDirectoriesFinder"
)

2.STATIC_ROOT

STATIC_ROOT = os.path.join(BASE_DIR, 'collect_static')#BASE_DIR是项目的绝对地址

STATIC_ROOT 是在部署静态文件时(pyhton manage.py collectstatic)所有的静态文静聚合的目录,

STATIC_ROOT要写成绝对地址,在这里,比如我的项目mysite是/home/mysite/ 那么STATIC_ROOT 为 /home/mysite/collect_static/

部署项目时,在终端输入:

python manage.py collectstatic

django会把所有的static文件都复制到STATIC_ROOT文件夹下

3.STATICFILES_DIRS

STATIC_ROOT 是在部署的时候才发挥作用, 而实际情况下,静态文件的一般安放位置有两种:

1.一种就是在每个app里面新建一个static文件夹,将静态文件放到里面,在加载静态文件时,比如要在模板中用到静态文件,

django会自动在每个app里面搜索static文件夹(所以,不要把文件夹的名字写错哦, 否则django就找不到你的文件夹了

2.另一种,就是在所有的app文件外面,建立一个公共的文件夹, 因为有些静态文件不是某个app独有的,那么就可以把它放

到一个公共文件夹里面,方便管理(注意,建立一个公共的静态文件的文件夹只是一种易于管理的做法,但是不是必须的,

app是可以跨app应用静态文件的,因为最后所有的静态文件都会在STATIC_ROOT里面存在) 那现在的问题是如何让

django知道你把一些静态文件放到app以外的公共文件夹中呢,那就需要配置STATICFILES_DIRS了

STATICFILES_DIRS = (
 os.path.join(BASE_DIR, 'common_static'),
)

STATICFILES_DIRS告诉django,首先到STATICFILES_DIRS里面寻找静态文件,其次再到各个app的static文件夹里面找(注意, django查找静态文件是惰性查找,查找到第一个,就停止查找了)

3.STATIC_URL

那么到此为止,静态文件的机制就可以运作了,但是有一个问题,我能不能通过url直接访问我在项目中的静态文件呢,答案肯定是啦,但是,注意,你是在浏览器是访问,你不可能输入你的静态文件的本地绝对地址吧,比如我的一种图片的本地地址为 /home/mysite/common_static/myapp/photo.png

那么别人不可能在浏览器上直接输入:
http://192.168.1.2:8000/home/mysite/common_static/myapp/photo.png

这样子,浏览器会报错, 没有该页面

那么django是如何让浏览器也可以访问服务器上的静态文件呢,前面已经说了,直接访问服务器本地的地址是不行的,那就需要一个映射,django利用STATIC_URL来让浏览器可以直接访问静态文件,比如:

STATIC_URL = '/static/'

那么可以在浏览器上输入:
http://192.168.1.2:8000/static/common_static/myapp/photo.png

那么就相当与访问/home/mysite/common_static/myap/photo.png

所以在浏览器上,利用前缀 STATIC_URL的具体内容,来映射STATIC_ROOT,
HTTP://192.168.1.2:8000/static 相当于 本地地址的STATIC_ROOT

参考文中:https://3water.com/article/139718.htm

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python批量导出导入MySQL用户的方法
Nov 15 Python
python写xml文件的操作实例
Oct 05 Python
python实现中文转换url编码的方法
Jun 14 Python
浅谈python中列表、字符串、字典的常用操作
Sep 19 Python
Python实现字典的遍历与排序功能示例
Dec 23 Python
Pandas分组与排序的实现
Jul 23 Python
Django中modelform组件实例用法总结
Feb 10 Python
python GUI库图形界面开发之PyQt5打印控件QPrinter详细使用方法与实例
Feb 28 Python
Python定时从Mysql提取数据存入Redis的实现
May 03 Python
在pycharm中关掉ipython console/PyDev操作
Jun 09 Python
Python Django路径配置实现过程解析
Nov 05 Python
Pytorch中的数据集划分&正则化方法
May 27 Python
Python实现计算圆周率π的值到任意位的方法示例
May 08 #Python
Python实现抓取HTML网页并以PDF文件形式保存的方法
May 08 #Python
Python读写docx文件的方法
May 08 #Python
python docx 中文字体设置的操作方法
May 08 #Python
Python解析并读取PDF文件内容的方法
May 08 #Python
python-docx修改已存在的Word文档的表格的字体格式方法
May 08 #Python
对Python中gensim库word2vec的使用详解
May 08 #Python
You might like
在WordPress中实现发送http请求的相关函数解析
2015/12/29 PHP
Yii2 rbac权限控制之rule教程详解
2016/06/23 PHP
PHP下 Mongodb 连接远程数据库的实例代码
2017/08/30 PHP
javascript中字符串的定义示例代码
2013/12/19 Javascript
从数组中随机取x条不重复数据的JS代码
2013/12/24 Javascript
jquery跟js初始化加载的多种方法及区别介绍
2014/04/02 Javascript
JavaScript返回当前会话cookie全部键值对照的方法
2015/04/03 Javascript
Node.js编程中客户端Session的使用详解
2015/06/23 Javascript
详解JS中Array对象扩展与String对象扩展
2016/01/07 Javascript
自己动手制作基于jQuery的Web页面加载进度条插件
2016/06/03 Javascript
javascript作用域、作用域链(菜鸟必看)
2016/06/16 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
根据Bootstrap Paginator改写的js分页插件
2016/12/25 Javascript
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
Vue 按键修饰符处理事件的方法
2018/05/04 Javascript
element-ui tree结构实现增删改自定义功能代码
2020/08/31 Javascript
[01:07:15]DOTA2-DPC中国联赛 正赛 DLG vs XG BO3 第二场 1月25日
2021/03/11 DOTA
python利用dir函数查看类中所有成员函数示例代码
2017/09/08 Python
教你一步步利用python实现贪吃蛇游戏
2019/06/27 Python
Python3 合并二叉树的实现
2019/09/30 Python
Django+python服务器部署与环境部署教程详解
2020/03/30 Python
Python如何在循环内使用list.remove()
2020/06/01 Python
树莓派4B安装Tensorflow的方法步骤
2020/07/16 Python
HTML5 通信API 跨域门槛将不再高、数据推送也不再是梦
2013/04/25 HTML / CSS
村捐赠仪式答谢词
2014/01/21 职场文书
《都江堰》教学反思
2014/02/07 职场文书
《风娃娃》教学反思
2014/04/19 职场文书
世博会口号
2014/06/20 职场文书
2014年小学教师工作自我评价
2014/09/22 职场文书
党的群众路线个人对照检查材料
2014/09/23 职场文书
公司副总经理岗位职责
2014/10/01 职场文书
乡村教师党员四风问题对照检查材料思想汇报
2014/10/08 职场文书
人事专员岗位职责
2015/02/03 职场文书
zabbix监控mysql的实例方法
2021/06/02 MySQL
SQL Server中常用截取字符串函数介绍
2022/03/16 SQL Server
SQL Server #{}可以防止SQL注入
2022/05/11 SQL Server