Django静态资源URL STATIC_ROOT的配置方法
程序员文章站
2023-11-23 22:43:46
缘由
新手学习 django 当配置好 html 页面后,就需要使用一些静态资源,如图片,js 文件,css 样式等,但是 django 里面使用这些资源并不是直接引...
缘由
新手学习 django 当配置好 html 页面后,就需要使用一些静态资源,如图片,js 文件,css 样式等,但是 django 里面使用这些资源并不是直接引用一下就好,还要配置路径即 static_url 如果这个配置不好的话,请求这些静态资源将返回 http 404 。
经验传授
1. 输出 settings.py 文件里面的 static_url 到html页面,看一下物理路径指向了哪些,通常是不是跑出根目录的。这里给个demo:
复制代码 代码如下:
def home(request):
t = get_template("index.html")
html = t.render(context({
"template_dir":settings.template_dirs[0],
"title":"home",
"static_dir":settings.static_root}))
return httpresponse(html)
这样访问的html页面就可以看到这些路径了。
2. 配置 static_root 变量
复制代码 代码如下:
static_root = os.path.join(os.path.dirname(__file__), '..', 'templates/content').replace('\\','/')
可能通过调整第二个和第三个参数来将路径修改正确。(多调试)
3. 在 urls.py 文件中配置 urlpatterns 变量(主要看高亮这一行):
复制代码 代码如下:
urlpatterns = patterns('',
url(r'^$', home),
url(r'^static/(?p<path>.*)$','django.views.static.serve',{'document_root':settings.static_root}),
)
4. 测试以上配置:
复制代码 代码如下:
<head>
<meta charset="utf-8"/>
<title>{{ title }} - oger</title>
<script type="text/javascript" src="/static/scripts/jquery-1.11.0.min.js"></script>
</head>
或
<head>
<meta charset="utf-8"/>
<title>{{ title }} - oger</title>
{% load staticfiles %}
<script type="text/javascript" src="{% static 'scripts/jquery-1.11.0.min.js' %}"></script>
</head>
[/code]
这两种用法都是可以的。
用 django 开发web站点还是很方便的。继续学习中...