django2.1 html显示图片的两种方式

第一种
图片所在文件加位于项目的根目录:dj/image/1.jpg
这时可以在setting.py文件中加上如下:

STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
    os.path.join(BASE_DIR),
#BASE_DIR是项目跟目录
]

STATIC_URI=’/static/'的作用是当链接中含有/static/时,链接后面的文件django会在各个app中的static 文件夹中查找对应的文件,而STATICFILES_DIRS的作用是,在app中没有找到对应的文件时也会在其指定的目录下去寻找文件。因此我们要访问 www.123.com/static/image/1.jpg 时,django除了在app下的static文件夹寻找,还会在 dj/static/ 和dj/下寻找。
第二种

    re_path(r'^image/(?P.*)$', serve, {'document_root': os.path.join(BASE_DIR, 'image')})

dj2.0以后普通的url直接使用path写就可以,不用使用正则。而想用正则时,则要使用re_path ,否则正则不生效。serve 是from django.views.static import serve 从这导入的。当访问 www.123.com/image/1.jpg 时,dj就会在dj/image下查找文件。这个url匹配既可以写在项目的urls.py中,也可以写在各app的urls.py中。第二种方法的好处就是可以将文件存在任何地方,而且文件的url也不要求是统一的。如果使用第一种方法,则所有静态文件的url都必须以‘static’开头。
由于在实际项目中,图片类的文件都是存储在第三方服务器上,所有在html中要生成绝对路径,在model中定义的ImageField字段中,自动含有一个url属性,这个属性可以根据setting文件中的MEDIA_URL的值生成一个绝对路径。,如果没有设置这个值,则还是相对路径,如果你的图片又不在本地服务器,那就访问不到了。
总结:
1,保证图片等文件的路径一定是以/static/开头,则可以将文件保存在各app中的static文件夹中,或者你自己定义一个目录,并将这个目录添加到STATICFILES_DIRS,在html中设置url时要使用模板的
2,可以将文件存到任何位置,在url匹配中,使用re_path(r’^/(?P .*)$’, serve, {‘document_root’: os.path.join(BASE_DIR, ‘image’)}) 也可以访问到图片资源。
3,在html中图片的地址可以使用相对地址,也可以使用绝对地址,image.url可以使用setting中的MEDIA_URL拼接出一个绝对路径。

你可能感兴趣的:(django2.1 html显示图片的两种方式)