亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

分離django中的媒體文件,靜態(tài)文件和網(wǎng)頁

yuanzhanghu / 3335人閱讀

摘要:前言文章會在中持續(xù)更新作者聯(lián)系我項(xiàng)目中,占很大體積的是靜態(tài)文件,媒體文件還有代碼,那我們該如何把它們分離出來以方便我們和服務(wù)器去管理和使用它們。

前言

文章會在github中持續(xù)更新

作者: knthony

github

聯(lián)系我

django項(xiàng)目中,占很大體積的是靜態(tài)文件,媒體文件還有html代碼,那我們該如何把它們分離出來以方便我們和服務(wù)器去管理和使用它們。

static 文件

static,顧名思義就是靜態(tài)文件,django自帶了一個命令講項(xiàng)目中所有的靜態(tài)文件提取出來
python3 manage.py collectstatic

我習(xí)慣將這些可以從外部引入的文件放在項(xiàng)目的根目錄下

DemoProject
--DemoProject
--DemoApp
--static
--manage.py

是的,就是它,我喜歡的位置。
不過在此之前,我們需要在項(xiàng)目的setting.py中去設(shè)置提取文件所要存儲的位置STATIC_ROOT

STATIC_ROOT = os.path.join(BASE_DIR, "static")

那這樣,我們運(yùn)行完上面的命令就會發(fā)現(xiàn)我們的項(xiàng)目結(jié)構(gòu)中會多一個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)然這個if判斷是在debug為true的時候支持這樣的訪問,那如果在真實(shí)生產(chǎn)環(huán)境中需要修改遮蓋判斷
不過到這里還沒有結(jié)束,為了方便的引用我們需要在setting.py中添加

STATICFILES_DIRS = [
    ("bootstrap",os.path.join(BASE_DIR, "static/bootstrap").replace("","/")),
]

注意這種方式在html中可以直接以如下方式訪問

注意要在第一行加上{% load staticfiles %}

media文件

網(wǎng)站上總是會有音樂視頻或者圖片等體積比較大的文件,那我們將這些也從django項(xiàng)目中分離出來并進(jìn)行調(diào)用
首先我們在和static同目錄下新建一個media文件夾,在media中新建一個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)

說出來你可能不信,這樣就ok了

這樣就可以訪問我們的media/image下的圖片或者視頻了

templates

如果我們想把項(xiàng)目中的網(wǎng)頁代碼文件歸類分離出來
第一步:

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)頁代碼的路徑,如果也想和我一樣放在根路徑下可以和我一樣

os.path.join(BASE_DIR, "templates").replace("","/"),

這是最近寫django項(xiàng)目總結(jié)的一點(diǎn)點(diǎn),第一次寫文章,大牛勿噴,感謝大牛能指出文中的缺漏和錯誤

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/38198.html

相關(guān)文章

  • Django項(xiàng)目前端工程化的探索

    摘要:項(xiàng)目前端工程化的探索不通過層實(shí)現(xiàn)非網(wǎng)頁開發(fā)的前后端分離。做過這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來,其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫,當(dāng)然也可以開一個前端工程來寫,最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過node層實(shí)現(xiàn)非SPA網(wǎng)頁開發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...

    jsummer 評論0 收藏0
  • Django項(xiàng)目前端工程化的探索

    摘要:項(xiàng)目前端工程化的探索不通過層實(shí)現(xiàn)非網(wǎng)頁開發(fā)的前后端分離。做過這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來,其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫,當(dāng)然也可以開一個前端工程來寫,最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過node層實(shí)現(xiàn)非SPA網(wǎng)頁開發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...

    buildupchao 評論0 收藏0
  • Django項(xiàng)目前端工程化的探索

    摘要:項(xiàng)目前端工程化的探索不通過層實(shí)現(xiàn)非網(wǎng)頁開發(fā)的前后端分離。做過這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來,其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫,當(dāng)然也可以開一個前端工程來寫,最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過node層實(shí)現(xiàn)非SPA網(wǎng)頁開發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...

    Jackwoo 評論0 收藏0
  • Django項(xiàng)目前端工程化的探索

    摘要:項(xiàng)目前端工程化的探索不通過層實(shí)現(xiàn)非網(wǎng)頁開發(fā)的前后端分離。做過這樣項(xiàng)目的各位攻城獅應(yīng)該都知道有多痛苦吧。仔細(xì)想來,其實(shí)只是想要模板和靜態(tài)資源,我們可以直接在目錄下寫,當(dāng)然也可以開一個前端工程來寫,最后把模板和靜態(tài)資源到工程的相應(yīng)目錄下。 Django項(xiàng)目前端工程化的探索 不通過node層實(shí)現(xiàn)非SPA網(wǎng)頁開發(fā)的前后端分離。 技術(shù)棧:webpack + jade + es6 + scss +...

    HackerShell 評論0 收藏0
  • uwsgi+nginx項(xiàng)目部署

    摘要:部署項(xiàng)目部署一個的開源框架。輪詢負(fù)載均衡在配置文件中添加如下配置,此配置有三臺服務(wù)器提供支付服務(wù)。缺省配置就是輪詢策略負(fù)載均衡支持和協(xié)議,只需要修改后面的協(xié)議即可支持的負(fù)載均衡只需將改為即可。 部署Django項(xiàng)目 Django+uWSGI+nginx 部署 django 一個pyhton的開源web框架。 uWSGI 一個基于自有的uwsgi協(xié)議、WSGI協(xié)議和http服務(wù)協(xié)議的w...

    betacat 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<