溫馨提示×

溫馨提示×

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

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

Django修改了css文件不生效的解決方法

發布時間:2021-05-19 09:41:27 來源:億速云 閱讀:526 作者:小新 欄目:web開發

這篇文章主要介紹了Django修改了css文件不生效的解決方法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

解決方法: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

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Django修改了css文件不生效的解決方法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

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

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女