對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法
在一個網(wǎng)頁中,不僅僅只有一個html骨架,還需要css樣式文件,js執(zhí)行文件以及一些圖片等。因此在DTL中加載靜態(tài)文件是一個必須要解決的問題。在DTL中,使用static標簽來加載靜態(tài)文件。要使用static標簽,首先需要{% load static %}。
加載靜態(tài)文件的步驟如下:
首先確保django.contrib.staticfiles已經(jīng)添加到settings.INSTALLED_APPS中。
確保在settings.py中設(shè)置了STATIC_URL。
注意: 上面兩條都是在創(chuàng)建Django 項目的時候就自動給我們弄好了,只要我們沒有去改動它,就不用管。
在已經(jīng)安裝了的app下創(chuàng)建一個文件夾叫做static,然后再在這個static文件夾下創(chuàng)建一個當前app的名字的文件夾,再把靜態(tài)文件放到這個文件夾下。例如你的app叫做book,有一個靜態(tài)文件叫做book.jpg,那么路徑為book/static/book/book.jpg。(為什么在app下創(chuàng)建一個static文件夾,還需要在這個static下創(chuàng)建一個同app名字的文件夾呢?原因是如果直接把靜態(tài)文件放在static文件夾下,那么在模版加載靜態(tài)文件的時候就是使用book.jpg,如果在多個app之間有同名的靜態(tài)文件,這時候可能就會產(chǎn)生混淆。而在static文件夾下加了一個同名app文件夾,在模版中加載的時候就是使用app名/book.jpg,這樣就可以避免產(chǎn)生混淆。)
注意: 文件夾的名字必須為static 。
如果有一些靜態(tài)文件是不和任何app掛鉤的。即不再任何一個app的目錄下。那么可以在settings.py中添加STATICFILES_DIRS,以后DTL就會在這個列表的路徑中查找靜態(tài)文件。例如我們在manage.py的同級目錄下新建一個static的文件夾。然后在settings.py:中添加STATICFILES_DIRS
STATICFILES_DIRS = [ os.path.join(BASE_DIR,"static") ]
注: 第三種和第四種方法都可以加載靜態(tài)文件,我的個人習慣是在manage.py的同級目錄下新建一個static文件夾,然后將所有的靜態(tài)文件進行分類的在里面存儲。而不去app中新建一個static的文件夾。但這只是我的個人習慣。畢竟不管是黑貓白貓,能抓到老鼠的就是好貓,所以只要我們能把項目做出來能運行,并且代碼結(jié)構(gòu)有邏輯性、層次感就行了。
在模版中使用load標簽加載static標簽。比如要加載在項目的static文件夾下的style.css的文件。那么示例代碼如下:
{% load static %} <link rel="stylesheet" href="{% static 'style.css' %}" rel="external nofollow" >
注意: {% load static %}需要放在html的頭部位置(至少在使用static標簽的上面),一般都是放在html的最上面。如果{% extend %}標簽和{% load static %}同時存在,{% extend %}需要放在最上面,然后再放{% load static %}等標簽。
如果不想每次在模版中加載靜態(tài)文件都使用load加載static標簽,那么可以在settings.py中的TEMPLATES/OPTIONS添加'builtins':['django.templatetags.static'],這樣以后在模版中就可以直接使用static標簽,而不用手動的load了。
注意: 位置不要添加錯誤了
TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [os.path.join(BASE_DIR, 'templates')] , 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], #添加在這個位置 'builtins' : [ 'django.templatetags.static' ], }, }, ]
下面的不常用,但是可以了解一下。
如果沒有在settings.INSTALLED_APPS中添加django.contrib.staticfiles。那么我們就需要手動的將請求靜態(tài)文件的url與靜態(tài)文件的路徑進行映射了。
示例代碼如下:
from django.conf import settings from django.conf.urls.static import static urlpatterns = [ # 其他的url映射 ] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
但平時我們并不會用到這個,Django內(nèi)置已經(jīng)將django.contrib.staticfiles添加進去了的,我們?yōu)槭裁匆o他刪除來自找麻煩呢?放在這里也只是提供一個參考,了解一下。
最后分享一個快捷鍵的使用:在我們寫項目的時候,有時候修改了代碼而沒有效果,這是因為瀏覽器使用的緩存加載,這個時候我們就可以使用這個快捷鍵來不使用緩存加載一個文件,來達到查看修改代碼之后的效果的目地。
ctrl+shift+r 不使用緩存加載一個文件
以上這篇對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- 如何配置vue.config.js 處理static文件夾下的靜態(tài)文件
- PHP中abstract(抽象)、final(最終)和static(靜態(tài))原理與用法詳解
- 快速解決Django關(guān)閉Debug模式無法加載media圖片與static靜態(tài)文件
- Python 類方法和實例方法(@classmethod),靜態(tài)方法(@staticmethod)原理與用法分析
- .Net Core中間件之靜態(tài)文件(StaticFiles)示例詳解
- 詳解Vue-cli中的靜態(tài)資源管理(src/assets和static/的區(qū)別)
- django中靜態(tài)文件配置static的方法
- 通過案例了解靜態(tài)修飾符static使用場景
相關(guān)文章
如何解決pycharm中用matplotlib畫圖不顯示中文的問題
這篇文章主要介紹了如何解決pycharm中用matplotlib畫圖不顯示中文的問題,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-06-06pandas.DataFrame.drop_duplicates 用法介紹
這篇文章主要介紹了pandas.DataFrame.drop_duplicates 用法介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07Python實現(xiàn)冒泡排序的簡單應(yīng)用示例
這篇文章主要介紹了Python實現(xiàn)冒泡排序的簡單應(yīng)用,結(jié)合實例形式分析了Python基于冒泡排序?qū)崿F(xiàn)的輸入字符串數(shù)字排序與運算操作,需要的朋友可以參考下2017-12-12