解決django的template中如果無(wú)法引用MEDIA_URL問題
配置如下
TEMPLATES = [
下面
’context_processors’: [
中添加
’django.core.context_processors.media’,
會(huì)把MEDIA_URL 配置在template中
這樣在template下面 就可以引用MEDIA_URL了
補(bǔ)充知識(shí):在django中使用 MEDIA_URL 和 MEDIA_ROOT
在django上傳圖片前端使用動(dòng)態(tài)的配置方法
MEDIA_ROOT 代表著 要上傳的路徑會(huì)和你在models中寫的上傳的路徑進(jìn)行拼節(jié)形成最終文件上傳的路徑
MEDIA_URL主要就是映射了 在前端使用media_url當(dāng)你的media_root發(fā)生改變的時(shí)候不用去更改前端模板中的內(nèi)容
前端模板中的寫法
后面是從數(shù)據(jù)庫(kù)中 查詢出來(lái)的 上傳文件的地址url
'{{ MEDIA_URL }}{{ course_org.image }}'
前端生成的路徑
'/media/org/2017/07/qhdx-logo.png'/
要想正常的顯示圖片 還需要下面幾步:
1 在settings 中配置路徑
MEDIA_URL = ’/media/’MEDIA_ROOT = os.path.join(BASE_DIR, ’media’)
2 在TEMPLATES 中添加一個(gè)上下文環(huán)境 ’django.core.context_processors.media’, 這個(gè)會(huì)
自動(dòng)的把MEDIA_URL 注冊(cè)到前端的模板中的 沒有這個(gè)上下文環(huán)境 MEDIA_URL在前端是沒有顯示的
TEMPLATES = [ { ’BACKEND’: ’django.template.backends.django.DjangoTemplates’, ’DIRS’: [os.path.join(BASE_DIR, ’templates’)] , ’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’,’django.core.context_processors.media’, ], }, },
3 在url中配置media請(qǐng)求的url
首先需要導(dǎo)入下面的庫(kù) 和在settings 中配置的 MEDIA_ROOT上傳路徑
from django.views.static import servefrom MxOnline.settings import MEDIA_ROOT
配置url 固定的 里面的內(nèi)容不能改的
url(r’media/(?P<path>.*)$’, serve, {’document_root’: MEDIA_ROOT}),
以上這篇解決django的template中如果無(wú)法引用MEDIA_URL問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python GUI庫(kù)圖形界面開發(fā)之PyQt5動(dòng)態(tài)(可拖動(dòng)控件大小)布局控件QSplitter詳細(xì)使用方法與實(shí)例2. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)3. CSS清除浮動(dòng)方法匯總4. 不要在HTML中濫用div5. 父div高度不能自適應(yīng)子div高度的解決方案6. js開發(fā)中的頁(yè)面、屏幕、瀏覽器的位置原理(高度寬度)說(shuō)明講解(附圖)7. XML 非法字符(轉(zhuǎn)義字符)8. Python數(shù)據(jù)分析JupyterNotebook3魔法命令詳解及示例9. ASP動(dòng)態(tài)include文件10. vue跳轉(zhuǎn)頁(yè)面常用的幾種方法匯總
