Django静态文件的处理

一、Django中setting.py对静态文件的设置

  在setting.py文件中对静态文件的设置主要有:

INSTALLED_APPS = ( .... .... ‘django.contrib.staticfiles‘, .... )

STATIC_ROOT = ‘‘

STATIC_URL = ‘/static/‘

STATICFILES_FINDERS = (

   ‘django.contrib.staticfiles.finders.FileSystemFinder‘,

   ‘django.contrib.staticfiles.finders.AppDirectoriesFinder‘,

   ‘django.contrib.staticfiles.finders.DefaultStorageFinder‘,

)

STATICFILES_DIRS = ()

  1、INSTALLED_APPS = ( .... .... ‘django.contrib.staticfiles‘, .... )

  django.contrib.staticfiles是Django自带的默认的静态文件管理应用。

  2、STATIC_ROOT

  当项目开发完毕,需要部署时,使用python manage.py collectstatic,将该项目所用到的全部静态文件集中到static_root定义的目录内,在开发阶段无用。

  3、STATIC_URL=‘/static/‘

  Django默认会在static_url目录下处理静态文件。当我们发起一个 /static/style.css 的请求,Django知道 STATIC_URL设置为‘/static/‘,这跟url提供的第一个部分相匹配,因此它推断我们想要将/static/下的style.css作为静态文件处理。

  4、STATICFILES_FINDERS

  静态文件搜索路径设置:FileSystemFinder告诉后台从STATICFILES_DIRS内指定的目录进行搜索;AppDirectoriesFinder告诉后台从app的目录进行搜索;DefaultStorageFinder告诉后台从DFAULT_FILE_STORAGE定义的目录进行搜索。

  一般情况下,若在setting.py中设置了STATICFILES_DIRS,系统会在STATICFILES_DIRS内指定的目录进行搜索;若没有,再进入app目录下进行搜索。若在setting.py中没有设置了STATICFILES_DIRS,系统会直接到app目录下进行搜索。

  5、STATICFILES_DIRS

  Django默认的静态文件搜索路径,主要用于存放项目公用的静态文件。该目录下的路径不可与STATIC_ROOT相同

二、防止静态文件硬编码

  1、什么是硬编码

  硬编码是指将可变变量用一个固定值来代替的方法。用这种方法编译后,如果以后需要更改此变量就非常困难了。大部分程序语言里,可以将一个固定数值定义为一个标记,然后用这个特殊标记来取代变量名称。当标记名称改变时,变量名不变,这样,当重新编译整个程序时,所有变量都不再是固定值,这样就更容易的实现了改变变量的目的。

  2、Django中静态文件如何防止硬编码

  例如<img src="/static/css/bootstrap.css" type="text/css" rel="stylesheet">可改为

  {%load static%}

  <img src="{%static "css/bootstrap.css"%}" type="text/css" rel="stylesheet">

三、Django在开发阶段的静态文件处理习惯

  1、在app文件夹中创建static目录

  2、若各app的静态文件名相同,但内容不同,常在app下的static目录中在建立一个目录,如project/app/static/appname/css.css

时间: 2024-08-02 10:16:16

Django静态文件的处理的相关文章

Django静态文件输出

一直很纠结的一个问题,网络上也有很多方案,但总感觉不完美. 之前的方案 1 .  在setting.py中     STATIC_ROOT = 'static/'     STATIC_URL = 'static/'      2.  在模板页面中     <link rel="stylesheet" href="{{ STATIC_URL }}css/bootstrap.css">     <script type="text/java

Django静态文件static的配置

Django静态文件static的配置 static文件夹的作用 ? static文件夹一般用于存放css,js,图片等静态文件 配置方式 ? 1.创建static文件夹 ? 2.在settings.py文件中新建一项(如果有则无需新建) STATIC_URL = '/static/' ? 3.在settings.py文件中新建一项 STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), ] ? 4.引用静态文件中的文件 ? 列如引用一个cs

55 Django静态文件配置

一.Django静态文件配置 1.项目文件夹,新建一个文件夹statics 文件夹 2.在配置文件settings.py中,配置: 文件中有第句: STATIC_URL = '/static/'#静态文件物理地址的别名 在上一句文件中下加一句: 在上一句文件中下加一句: STATICFILES_DIRS=[ os.path.join(BASE_DIR,"statics")] #静态文件的物理地址 3.把静态文件放在statics 文件夹中 4.html文件在引用静态文件时: <s

Django静态文件配置、request方法、ORM简介、字段的增删改查

app的创建注意事项: 在Django新创建的app要在seetings.py中添加注册,才会生效 创建app:django-adminapp an startapp app名称 或者 python3 mansge.py startpp名称 手动创建的app不会自带存放html的templates文件夹,需要手动创建 Django静态文件配置 对于前端已经写好了的文件,我们只是拿过来使用,那么这些文件都可以称之为"静态文件"; 静态文件可以是:boostrap一类的前端框架,已经写好了

Django 静态文件配置(static files)

Django version: 1.9 Python versrion: 3.5.2 这几天Django配置静态文件(本例是要加载index.css), 总是不对,最后终于试对了,这里记录下,方便以后查阅 最后实在没办法把Django1.9的官方文档下载下来(网页版),仔细的阅读了下相关的章节. 首先看下项目的结构图(pycharm2016 professional): 1.首先在INSTALLED_APPS中要有'django.contrib.staticfiles' INSTALLED_AP

Django——静态文件配置

本文目的 最近用django开发项目,发现django的静态文件(js,css和img等)配置比较麻烦,开发环境和生产环境的配置还不一样,这里记录一下,作为备忘.我当前使用的版本是django v1.4.3. 吐槽:django的版本不兼容是个大问题,网上搜索相关问题时,解决方案到是一大推,但是均没有标注版本,导致均不能适用当前版本,走了不少弯路. 开发环境配置 需要下面几个步骤 1. 在app目录下创建static目录,将静态文件和相关文件夹放到此目录下,如your_app/static/im

django静态文件查找逻辑

最近被django的静态文件配置整疯了. 决定直捣黄龙,看看底层代码: 首先用manage finstatic xxxx.js 看看处理逻辑,发现主要在:C:\Python27\Lib\site-packages\django\contrib\staticfiles\finders.py中的find函数,如下: 调试进入:C:\Python27\Lib\site-packages\django\contrib\staticfiles\finders.py的FileSystemFinder类的fi

Django——静态文件(如bootstrap)的配置

静态文件如CSS, javascript(如bootstrap), 图片等文件在django中的配置官方文档写的比较模糊,自己通过实验验证后并整理如下,以防遗忘,目前只整理了关于本地开发中的设置方式,实际发布的配置方式稍后整理. ——————————————————————经测试使用第一种方法————————————————————————————————— [第一部分:配置] 步骤一:配置STATICFILES_DIRS 两种情况: 1. 默认情况,静态文件放在app目录下的static目录中

Django 静态文件 static

一.概述: #静态文件交由Web服务器处理,Django本身不处理静态文件.简单的处理逻辑如下(以nginx为例): # URI请求-----> 按照Web服务器里面的配置规则先处理,以nginx为例,主要求配置在nginx. #conf里的location |---------->如果是静态文件,则由nginx直接处理 |---------->如果不是则交由Django处理,Django根据urls.py里面的规则进行匹配 # 以上是部署到Web服务器后的处理方式,为了便于开发,Dja