这篇文章主要讲解了“为什么django的template中无法引用MEDIA_URL”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“为什么django的template中无法引用MEDIA_URL”吧!
瀍河ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!配置如下
TEMPLATES = [
下面
'context_processors': [
中添加
'django.core.context_processors.media',
会把MEDIA_URL 配置在template中
这样在template下面 就可以引用MEDIA_URL了
补充知识:在django中使用 MEDIA_URL 和 MEDIA_ROOT
在django上传图片前端使用动态的配置方法
MEDIA_ROOT 代表着 要上传的路径会和你在models中写的上传的路径进行拼节形成最终文件上传的路径
MEDIA_URL主要就是映射了 在前端使用media_url当你的media_root发生改变的时候不用去更改前端模板中的内容
前端模板中的写法
后面是从数据库中 查询出来的 上传文件的地址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 中添加一个上下文环境 'django.core.context_processors.media', 这个会
自动的把MEDIA_URL 注册到前端的模板中的 没有这个上下文环境 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请求的url
首先需要导入下面的库 和在settings 中配置的 MEDIA_ROOT上传路径
from django.views.static import serve
from MxOnline.settings import MEDIA_ROOT
配置url 固定的 里面的内容不能改的
url(r'media/(?P
.*)$', serve, {'document_root': MEDIA_ROOT}),
感谢各位的阅读,以上就是“为什么django的template中无法引用MEDIA_URL”的内容了,经过本文的学习后,相信大家对为什么django的template中无法引用MEDIA_URL这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联成都网站设计公司,小编将为大家推送更多相关知识点的文章,欢迎关注!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。