vue 获取php图片报错,vue怎么插入图片

本文详细介绍了在Vue.js项目中如何实现图片上传到后端的完整流程。首先,需要在项目中创建一个static文件夹来存放图片。接着,在Vue组件中编写点击事件,使用FormData对象来封装图片数据,并通过axios发送POST请求到后端接口。后端通过request对象获取上传的图片数据并保存。整个过程包括前端的图片选择、数据封装、请求发送,以及后端的数据接收和存储。
摘要由CSDN通过智能技术生成

vue插入图片的方法:首先创建一个static文件夹用来保存图片;然后写点击事件,代码为【url:'/api/api/add/'】;最后在后端获取数据。

3f91fb288fbc143e9a33ad59c1aabfe3.png

本教程操作环境:windows7系统、Vue2.9.6版,该方法适用于所有品牌电脑。

vue插入图片的方法:

首先开始创建一个static文件夹用来保存图片

去 setting 里面进行配置MEDIA_ROOT = os.path.join(BASE_DIR,'media')

#前面大写的是死格式,尽量不要写错

一级路由里面写re_path(r'^media/(?P.*)$', serve, {'document_root': settings.MEDIA_ROOT})

在vue中的templates里这样写

姓名:

图片:
#这个ID是下面用来获取它的属性值的

添加

接下来我们就该写点击事件了 (这里用到了FormData:不了解的可以去它的官网去查一查:https://developer.mozilla.org/zh-CN/docs/Web/API/FormData/FormData)methods:{

my_add:function(){

let form_data = new FormData(); #实例化一个FormData

form_data.append('name',this.name); #把数据添加到这个实例中

let img = document.getElementById('img').files[0]; #获取id的属性

form_data.append('img',img); #把图拍片名称添加到这个实例中

this.axios({

url:'/api/api/add/', #连接后台接口 第一个api是跨域的配置,第二个api是我的后台一级路由

method:'post', #用post方法进行提交数据

headers:{'Content-Type':'multipart/form-data'}, #'Content-Type': 'multipart/form-data' :指定传输数据为二进制数据,例如图片、mp3、文件

data:form_data,

}).then(res=>{

if(res.data.code==200){

alert(res.data.message) #这是code等于200的时候打印的

}

else{

alert(res.data.message) #这是code等于其他值 的时候打印的

}

}).catch(err=>{

console.log(err) #把错误警告提交到console

})

}

}

后端获取数据name = request.data.get('name') #获取页面上输入的名字

img = request.FILES.get('img') #获取页面上添加的图片

img_name = img.name #取出文件的名字

img_path = 'static/upload/' + img_name #给图片名字前面拼接上路径 这就是它的路径

with open(img_path,'wb') as f: #循环写入文件‘wb’

for k in img.chunks(): #避免文件太大,就把它分成块写入

f.write(k)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值