解決方法: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等靜態檔案的正確姿勢…
#首先應該改確保你專案下的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/"
本地css檔案同步到伺服器之後,只是同步到了對應APP下面的static資料夾裡面,但是nginx等呼叫的是你設定的STATIC_ROOT資料夾下的文件,所以程式碼同步之後我們要進行這個非常重要的操作:
python manage.py collectstatic
運行完這條程式碼之後,剛剛修改過的main.css文件將會被收集到網站根目錄下的static檔案中,等待nginx的呼叫。
前兩步驟做完之後,你還需要重啟一下gunicorn和nginx,不過我沒有重啟也生效了,如果沒有生效的話建議執行此步驟。
# 查看gunicorn进程ID pstree -ap | grep gunicorn # 重启进程 kill -HUP ID
推薦學習:css視訊教學
以上是Django修改了css檔案不生效怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!