摘要:前言文章會(huì)在中持續(xù)更新作者聯(lián)系我項(xiàng)目中,占很大體積的是靜態(tài)文件,媒體文件還有代碼,那我們?cè)撊绾伟阉鼈兎蛛x出來(lái)以方便我們和服務(wù)器去管理和使用它們。
前言
文章會(huì)在github中持續(xù)更新
作者: knthony
github
聯(lián)系我
django項(xiàng)目中,占很大體積的是靜態(tài)文件,媒體文件還有html代碼,那我們?cè)撊绾伟阉鼈兎蛛x出來(lái)以方便我們和服務(wù)器去管理和使用它們。
static 文件static,顧名思義就是靜態(tài)文件,django自帶了一個(gè)命令講項(xiàng)目中所有的靜態(tài)文件提取出來(lái)
python3 manage.py collectstatic
我習(xí)慣將這些可以從外部引入的文件放在項(xiàng)目的根目錄下
DemoProject --DemoProject --DemoApp --static --manage.py
是的,就是它,我喜歡的位置。
不過(guò)在此之前,我們需要在項(xiàng)目的setting.py中去設(shè)置提取文件所要存儲(chǔ)的位置STATIC_ROOT
STATIC_ROOT = os.path.join(BASE_DIR, "static")
那這樣,我們運(yùn)行完上面的命令就會(huì)發(fā)現(xiàn)我們的項(xiàng)目結(jié)構(gòu)中會(huì)多一個(gè)static文件
然后配置DemoProject下的url,添加
from django.contrib.staticfiles.urls import staticfiles_urlpatterns from django.conf.urls.static import static from django.conf import settings urlpatterns = [ url(r"^admin/", admin.site.urls), ] if settings.DEBUG or True: urlpatterns += staticfiles_urlpatterns()
當(dāng)然這個(gè)if判斷是在debug為true的時(shí)候支持這樣的訪(fǎng)問(wèn),那如果在真實(shí)生產(chǎn)環(huán)境中需要修改遮蓋判斷
不過(guò)到這里還沒(méi)有結(jié)束,為了方便的引用我們需要在setting.py中添加
STATICFILES_DIRS = [ ("bootstrap",os.path.join(BASE_DIR, "static/bootstrap").replace("","/")), ]
注意這種方式在html中可以直接以如下方式訪(fǎng)問(wèn)
media文件注意要在第一行加上{% load staticfiles %}
網(wǎng)站上總是會(huì)有音樂(lè)視頻或者圖片等體積比較大的文件,那我們將這些也從django項(xiàng)目中分離出來(lái)并進(jìn)行調(diào)用
首先我們?cè)诤?b>static同目錄下新建一個(gè)media文件夾,在media中新建一個(gè)image作為我們存放圖片的文件夾
結(jié)構(gòu)如下:
DemoProject --DemoProject --DemoApp --static --media ---image --manage.py
第一步:在setting.py最后添加
MEDIA_URL = "/media/" MEDIA_ROOT = os.path.join(BASE_DIR, "media")
第二部:在urls.py中
在 urlpatterns += staticfiles_urlpatterns()
下面添加
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
說(shuō)出來(lái)你可能不信,這樣就ok了
這樣就可以訪(fǎng)問(wèn)我們的media/image下的圖片或者視頻了
templates如果我們想把項(xiàng)目中的網(wǎng)頁(yè)代碼文件歸類(lèi)分離出來(lái)
第一步:
TEMPLATES = [ { "BACKEND": "django.template.backends.django.DjangoTemplates", "DIRS": [ os.path.join(BASE_DIR, "templates").replace("","/"), ], "APP_DIRS": True, "OPTIONS": { "context_processors": [ "django.template.context_processors.debug", "django.template.context_processors.request", "django.contrib.auth.context_processors.auth", "django.contrib.messages.context_processors.messages", ], }, }, ]
在上面代碼的DIRS中添加你網(wǎng)頁(yè)代碼的路徑,如果也想和我一樣放在根路徑下可以和我一樣
os.path.join(BASE_DIR, "templates").replace("","/"),
這是最近寫(xiě)django項(xiàng)目總結(jié)的一點(diǎn)點(diǎn),第一次寫(xiě)文章,大牛勿噴,感謝大牛能指出文中的缺漏和錯(cuò)誤
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/38198.html
摘要:項(xiàng)目前端工程化的探索不通過(guò)層實(shí)現(xiàn)非網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。做過(guò)這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來(lái),其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫(xiě),當(dāng)然也可以開(kāi)一個(gè)前端工程來(lái)寫(xiě),最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過(guò)node層實(shí)現(xiàn)非SPA網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...
摘要:項(xiàng)目前端工程化的探索不通過(guò)層實(shí)現(xiàn)非網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。做過(guò)這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來(lái),其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫(xiě),當(dāng)然也可以開(kāi)一個(gè)前端工程來(lái)寫(xiě),最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過(guò)node層實(shí)現(xiàn)非SPA網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...
摘要:項(xiàng)目前端工程化的探索不通過(guò)層實(shí)現(xiàn)非網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。做過(guò)這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來(lái),其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫(xiě),當(dāng)然也可以開(kāi)一個(gè)前端工程來(lái)寫(xiě),最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過(guò)node層實(shí)現(xiàn)非SPA網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...
摘要:項(xiàng)目前端工程化的探索不通過(guò)層實(shí)現(xiàn)非網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。做過(guò)這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來(lái),其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫(xiě),當(dāng)然也可以開(kāi)一個(gè)前端工程來(lái)寫(xiě),最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過(guò)node層實(shí)現(xiàn)非SPA網(wǎng)頁(yè)開(kāi)發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...
摘要:部署項(xiàng)目部署一個(gè)的開(kāi)源框架。輪詢(xún)負(fù)載均衡在配置文件中添加如下配置,此配置有三臺(tái)服務(wù)器提供支付服務(wù)。缺省配置就是輪詢(xún)策略負(fù)載均衡支持和協(xié)議,只需要修改后面的協(xié)議即可支持的負(fù)載均衡只需將改為即可。 部署Django項(xiàng)目 Django+uWSGI+nginx 部署 django 一個(gè)pyhton的開(kāi)源web框架。 uWSGI 一個(gè)基于自有的uwsgi協(xié)議、WSGI協(xié)議和http服務(wù)協(xié)議的w...
閱讀 781·2023-04-25 16:55
閱讀 2821·2021-10-11 10:59
閱讀 2087·2021-09-09 11:38
閱讀 1800·2021-09-03 10:40
閱讀 1495·2019-08-30 15:52
閱讀 1134·2019-08-30 15:52
閱讀 965·2019-08-29 15:33
閱讀 3505·2019-08-29 11:26