vue用form上传图片_Vue formData实现图片上传

本文介绍了如何在Vue项目中使用formData实现图片上传。通过创建一个全局方法$uploadFile,监听input文件选择事件,将文件添加到formData中,然后利用axios进行multipart/form-data形式的数据请求,从而完成图片上传操作。
摘要由CSDN通过智能技术生成

本文实例为大家分享了Vue formData实现图片上传的具体代码,供大家参考,具体内容如下

import Vue from 'vue'

/**

* 图片上传

* 已注入所有Vue实例,

* template模板里调用 $uploadFile(id)

* 组件方法里调用 this.$uploadFile(id)

*/

const uploadFile = (id) => {

let promise = new Promise((resolve, reject) => {

let file = null

let el = null

let i = 0

let formData = new FormData()

document.getElementById(id).click()

el = document.getElementById(id)

el.addEventListener('change', function (e) {

i++

if (i !== 1) {

return false

} else {

file = this.files[0]

formData.append('file', file)

formData.append('fileType', 'IMAGE')

// 数据请求

Vue.axiosfrom(Vue.api.upload, formData).then(res => {

// 返回图片url

resolve(res)

}).catch(err => {

reject(err)

})

}

})

})

return promise

}

Vue.prototype.$uploadFile = uploadFile

axios请求头设置

import Vue from 'vue'

import { baseURL } from '@/config/env'

import axios from 'axios'

// formdata 请求

const axiosT = axios.create({

baseURL: baseURL,

headers: {

'Content-Type': 'multipart/form-data'

}

})

const XHR = ({method = 'post', qs = true, loading = false, loginRequire = true, reqComplex = false, reqContentType = 'urlencoded'}) => {

// 带请求进度条成功方法

const sucFunX = res => {

return res.data

}

// 成功执行方法

const sucFunC = res => {

return res.data

}

// 带请求进度条失败方法

const errFunX = err => {

console.log(err, NProgress.done())

}

// 失败执行访求

const errFunC = err => {

console.log(err)

}

// 判断是否需要Longing

const sucFun = loading ? sucFunX : sucFunC

// 判断是否需要Longing

const errFun = loading ? errFunX : errFunC

return {user, sucFun, errFun}

}

// 表单请求 图片上传

const axiosfrom = function (url = '', data = {}) {

let {sucFun, errFun} = XHR({loading: false})

return axiosT.post(url, data).then(sucFun).catch(errFun)

}

// 表单请求

Vue.prototype.$axiosfrom = axiosfrom

Vue.axiosfrom = axiosfrom

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值