首頁 >web前端 >css教學 >Django修改了css檔案不生效怎麼辦

Django修改了css檔案不生效怎麼辦

醉折花枝作酒筹
醉折花枝作酒筹原創
2021-05-18 17:11:254577瀏覽

解決方法:1、正確配置「settings.py」檔案裡的「STATIC_URL」和「STATIC_ROOT」;2、執行「python manage.py collectstatic」指令;3、重啟gunicorn和nginx即可。

本教學操作環境:windows7系統、CSS3&&HTML5版、Dell G3電腦。

將Django部署到伺服器之後,每一次在本地端對網站的修改都需要在服務端進行同步,在寫本文之前,我還以為只是把源碼保持同步就可以了,沒想到卻遇到了今天的問題。

修改了main.css檔案之後,然後我透過git對網站進行了同步,程式碼已經成功同步到了伺服器上。但就是無法正常顯示,經過一番查找探究之後,我發現了修改css等靜態檔案的正確姿勢…

#1.設定檔

#首先應該改確保你專案下的settings .py檔案已經正確配置了STATIC_URL和STATIC_ROOT:

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR,'static/')

請注意引號裡面的"/",多一個或少一個/",都會使你的修改無法生效,我就是因為這裡多了一個"/",翻了車。那這兩個參數具體是什麼意思呢?

STATIC_ROOT是一個絕對地址,它是在Django部署的時候才會用到,它所對應的資料夾是存放被從專案各個地方收集來的靜態文件,因為一個Django可能有多個APP,相應的,每個APP可能都會有自己的static文件,將各個APP中的靜態文件收集到一起是為了nginx統一使用。那這些文件是由誰來收集的呢?這個問題會在第二步的時候說到。

STATIC_URL的作用就是為了能夠瀏覽器訪問到你的靜態文件,起到了一個映射的作用。一般預設設定為"/static/"

2.收集檔案

本地css檔案同步到伺服器之後,只是同步到了對應APP下面的static資料夾裡面,但是nginx等呼叫的是你設定的STATIC_ROOT資料夾下的文件,所以程式碼同步之後我們要進行這個非常重要的操作:

python manage.py collectstatic

運行完這條程式碼之後,剛剛修改過的main.css文件將會被收集到網站根目錄下的static檔案中,等待nginx的呼叫。

3.重啟服務

前兩步驟做完之後,你還需要重啟一下gunicorn和nginx,不過我沒有重啟也生效了,如果沒有生效的話建議執行此步驟。

# 查看gunicorn进程ID
pstree -ap | grep gunicorn

# 重启进程
kill -HUP ID

推薦學習:css視訊教學

以上是Django修改了css檔案不生效怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn