北方影院子夜心跳,中移动扣费猫腻,鬼子帽子两侧的帘布有啥用 真相意外
很多时候在使用form向后台发送数据的时候,并不需要使用到表单组件。
例如时间戳、ip等,这个时候除了ajax之外,还可以使用html5的一个全新方法formdata;在input[type = file]的文件类型中,很多时候想要把一张图片或者是使用canvas绘制好的图像传送到后台时,无法赋值给file文件,只能转换为base64类型传送到后台,然后由后台转换为图片再进行服务器存储;此过程较为复杂;
使用formdata,只需创建新的formdata对象,将要发送的数据添加进去,后台即可接收;数据以及文件对象皆可;
1. 基本使用方式
template
<input class="file" name="file" type="file" accept="image/png,image/gif,image/jpeg" @change="update"/>
javascript
update (e) { let file = e.target.files[0] // console.log(file) let param = new formdata() // 创建form对象 param.append('file', file, file.name) // 通过append向form对象添加数据 param.append('id', this.$store.state.userid) // 添加form表单中其他数据 // withcredentials: true 使得后台可以接收表单数据 跨域请求 const instance = axios.create({ withcredentials: true }) // url为后台接口 instance.post('url', param) .then(this.succ) // 成功返回信息 调用函数 函数需自己定义,此处后面省略 .catch(this.servererror) // 服务器错误 调用对应函数 函数需自己定义,此处后面省略 }
2. 美化 input file 按钮 (拓展)
思路:
以上思路可以实现点击用户头像,通过表单上传更换头像,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
VUE+elementui组件在table-cell单元格中绘制微型echarts图
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
vue 路由懒加载中给 Webpack Chunks 命名的方法
网友评论