解決方法: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中文網其他相關文章!

在本週的綜述中:Firefox獲得了類似鎖匠的力量,三星的Galaxy Store開始支持Progressive Web Apps,CSS Subgrid正在Firefox發貨

在本週的綜述中:Internet Explorer進入Edge,Google搜索控制台吹捧新的速度報告,而Firefox給出了Facebook' s Notification

蓋茨比(Gatsby)進行了出色的處理和處理圖像。例如,它可以幫助您節省圖像優化的時間,因為您不必手動


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

Dreamweaver CS6
視覺化網頁開發工具