成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

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

yuanzhanghu / 3270人閱讀

摘要:前言文章會(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)

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

media文件

網(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

相關(guān)文章

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

    摘要:項(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 +...

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

    摘要:項(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 +...

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

    摘要:項(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 +...

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

    摘要:項(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 +...

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

    摘要:部署項(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...

    betacat 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<