溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Django怎么壓縮靜態(tài)文件

發(fā)布時間:2021-05-20 15:59:30 來源:億速云 閱讀:170 作者:Leah 欄目:開發(fā)技術(shù)

使用Django怎么壓縮靜態(tài)文件?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

django靜態(tài)文件配置原理

靜態(tài)文件配置就是為了讓用戶請求時django服務器能找到靜態(tài)文件返回。

首先要理解幾個概念:

  • 媒體文件:用戶上傳的文件

  • 靜態(tài)文件:css,js,image等

  • 開發(fā)環(huán)境:使用django內(nèi)置服務器處理靜態(tài)文件

  • 生產(chǎn)環(huán)境:使用apache2/nginx服務器處理靜態(tài)文件映射

所以在配置時要分清楚開發(fā)環(huán)境還是生產(chǎn)環(huán)境,這個后面會詳細介紹。

下面先介紹一下服務器查找靜態(tài)文件的原理,這樣我們才能更好的配置。

引言

在網(wǎng)站開發(fā)階段,對于靜態(tài)資源文件比如JS,CSS等文件都是未經(jīng)過壓縮合并處理的,這對于訪問量巨大的網(wǎng)站來說不僅浪費帶寬,而且也會影響網(wǎng)站的訪問速度。

django-compressor可以把js/css等靜態(tài)文件壓縮,這樣不僅有利于減少網(wǎng)站的請求次數(shù),還能節(jié)省網(wǎng)絡帶寬。

而這篇文章即是介紹使用如何使用Python的Django框架中的壓縮組件django-compressor!

下面就介紹如何在Django中集成django-compressor!

安裝django-compressor

安裝很簡單,pip安裝下就可以了:

$ pip install django-compressor

然后在'setting'的INSTALLED_APPS中添加

INSTALLED_APPS = [
 #others
 'compressor'
]

setting配置

首先確保django.contrib.staticfiles已經(jīng)包含在INSTALLED_APPS中,django1.6及以上版本是默認包含該app在其中的.

指定STATIC_URL

STATIC_ROOT = os.path.join(SITE_ROOT, 'collectedstatic')
# STATIC_URL是客戶端訪問靜態(tài)資源的根路徑配置 
STATIC_URL = '/static/'
STATICFILES = os.path.join(BASE_DIR, 'static')

配置STATICFILES_FINDERS

默認django會從每個app目錄的static子目錄下查找靜態(tài)文件,因此通常情況下你都是將相關靜態(tài)文件放在各自的app/static目錄下。Django怎么知道從app/static目錄查找靜態(tài)文件呢?Django有個默認配置項STATICFILES_FINDERS:

STATICFILES_FINDERS = (
 'django.contrib.staticfiles.finders.FileSystemFinder',
 'django.contrib.staticfiles.finders.AppDirectoriesFinder',
 #other
 'compressor.finders.CompressorFinder',
)

添加django-compressor配置:

Django-Compressor開啟與否取決于DEBUG參數(shù),默認是COMPRESS_ENABLED 與 DEBUG 的值相反。因為 Django-Compressor 的功能本身是用在生產(chǎn)環(huán)境下項目發(fā)布前對靜態(tài)文件壓縮處理的。因此想在開發(fā)階段 (DEBUG=True) 的時候做測試使用,需要手動設置 COMPRESS_ENABLED=True

COMPRESS_ENABLED = True
COMPRESS_OFFLINE = True
COMPRESS_CSS_FILTERS = [
 #creates absolute urls from relative ones
 'compressor.filters.css_default.CssAbsoluteFilter',
 #css minimizer
 'compressor.filters.cssmin.CSSMinFilter'
]
COMPRESS_JS_FILTERS = [
 'compressor.filters.jsmin.JSMinFilter'
]

使用

使用也很簡單,模板文件中添加模板標簽 <font color="red">{% load compress %}</font>

下面分別是css和js的使用方式

{% load compress %}
{% compress css %}
<link rel='stylesheet' href='{% static 'blog/css/style.css' %}' type='text/css'/>
{% endcompress %}
{% compress js %}
<script type="text/javascript" src="{% static 'blog/js/jquery-3.1.1.js' %}"></script>
{% endcompress %}

接著先運行命令:

$ python manage.py collectstatic --noinput

所有靜態(tài)資源都將拷貝到STATIC_ROOT指定的目錄中。

然后運行命令:

$ python manage.py compress --force

這樣就會把壓縮后的文件放在 <font color="red">STATIC_ROOT</font> 目錄下面,大功告成??!

每次修改了js、css文件后,都需要重新加載最新的文件到 <font color="red">STATIC_ROOT</font> 目錄下去,因此需要重新運行命令:

$ python manage.py collectstatic --noinput
$ python manage.py compress --force

關于使用Django怎么壓縮靜態(tài)文件問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業(yè)資訊頻道了解更多相關知識。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI