博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django 静态文件配置(static files)
阅读量:5281 次
发布时间:2019-06-14

本文共 2092 字,大约阅读时间需要 6 分钟。

Django version: 1.9

Python versrion: 3.5.2

 

因为据说除了Firefox之外的浏览器都会乱码, 所以放上截图

 

 

 

 

这几天Django配置静态文件(本例是要加载index.css), 总是不对,最后终于试对了,这里记录下,方便以后查阅

最后实在没办法把Django1.9的官方文档下载下来(),仔细的阅读了下相关的章节。

 

首先看下项目的结构图(pycharm2016 professional):

1.首先在INSTALLED_APPS中要有'django.contrib.staticfiles'

INSTALLED_APPS = [    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'news',]

 

2.在settings.py中加入:
STATIC_URL = '/static/'STATICFILES_DIRS = [    os.path.join(BASE_DIR,"news/static/"),]
 

3.加载静态文件时

{% load staticfiles %}

这里的路径是根据上面的文件结构来写的。

事实上在Django官方文档例子(投票系统Writing your first Django app, part 6中有讲到这些内容) 另外,有时出错误了可以这样修改:   将上面的 href="{% static 'news/css/index.css' %}改成:href="{% static 'css/index.css' %}   运行命令:python manage.py runserver 可能会有正的结果:      此时运行:python manage.py findstatic css/index.css   箭头指的地方的news是指news这个文件夹,这里要说的是第一条命令:python manage.py findstatic css/index.css找不到css   文件,那么肯定是这里路径的问题,这样修改路径后,可以找到index.css文件,那就可以到html中修改相应的路径了。 2017.11.02更新: 最近在写一个项目时出现了一个bug,开始一直没找到原因,最后发现是因为app与项目根目录下的静态文件同名, 导致冲突。这里更新下具体如何避免冲突的问题。 通常情况下,我们会在项目建立时在项目根目录建立一个static目录(上图中并没有,上图指最上面的目录树截图,下同), 创建时默认有一个templates目录,当项目越来越大时,我们不可能将所有静态文件都放在这个目录里,而是各app独立开来。 那么具体要怎么独立呢 项目根目录有 static目录---> 放公共的静态文件,如jquery, bootstrap等 templates目录--->放整个项目初始的网页等,如首页 app中,以上面的news为例: 先建立static目录: static中建立app名字(上图中的news)的次级目录,这是关键 news中再分别建立css,js,img等次级目录 templates与static一样,也是先建立以当前app名字命名的次级目录 做完这些,我们需要将app静态文件路径加入到setting中:
os.path.join(BASE_DIR, "news/static/"),
 

 注意,是在原有的要目录的静态文件的基础上添加。

同样的道理, 在网页或者视图函数中的路径也就加上对应的app名,例如在网页的的模板文件中(标签)

在没有相互独立时是这样的:

{% extends 'index.html' %}

 在设计相互独立后就该是这样的:

{% extends 'news/index.html' %}

 html中代码:

经过django渲染到浏览器后:

注意这里的users是与上图中的news一样是一个app,(实在找不到原来的代码了)

对于渲染后的结果我个人倾向于认为第一个 /static/css/bootstrap.min.css中的

static指代根目录中的static

而 /static/users/css/login.css中的static指代users/static/

因为这里对应你setting中的设置。

经过上面这一系列的设置,各app可以引用公共的静态文件,同时各app自己的静态文件也相对独立开来 ,来容易导致冲突
posted on
2016-11-17 17:16 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/Andy963/p/Django.html

你可能感兴趣的文章
Android异步加载网络图片
查看>>
python学习之 - XML
查看>>
css问题小计
查看>>
Laravel学习笔记(三)数据库 数据库迁移
查看>>
ORACLE查看并修改最大连接数
查看>>
box-flex不均分问题
查看>>
Python--GIL 详解
查看>>
Oracle数据导入Mysql中
查看>>
BZOJ-4424 &&CodeForces-19E Fairy DP+dfs (Link-Cut-Tree可A)
查看>>
MongoDB学习笔记——聚合操作之group,distinct,count
查看>>
大道至简读后感(第四章)
查看>>
IDA IDC Tutorials: Additional Auto-Commenting
查看>>
k8s-存储卷1-十二
查看>>
在Android中Intent的概念及应用(二)——Intent过滤器相关选项
查看>>
数据库备份问题
查看>>
前端面试题(4)iframe有哪些优点?iframe缺点是什么?
查看>>
第十六章 多态性(一)
查看>>
INSERT IGNORE INTO / REPLACE INTO
查看>>
Python数据类型-布尔/数字/字符串/列表/元组/字典/集合
查看>>
MFC中theApp
查看>>