浏览器上传图片到服务端,我用过两种方法:

1.本地图片转换成base64,然后通过普通的post请求发送到服务端。
操作简单,适合小图,以及如果想兼容低版本的ie没办法用此方法
2.通过form表单提交。
form表单提交图片会刷新页面,也可以时form绑定到一个隐藏的iframe上,可以实现无刷新提交数据。但是如果想传输多条form表单数据,需要写很多dom,同时还要写iframe,太麻烦。
目前感觉比较干净的办法就是通过axios的post请求,发送form数据到后台。
html部分,至于界面优化,可以把input file的opacity设置为0,点击其父容器,即触发file
复制代码 代码如下:
<input class="file" name="file" type="file" accept="image/png,image/gif,image/jpeg" @change="update"/>
axios的post请求,发送form数据部分,这样就可以无刷新的提交form数据到后台
update(e){
let file = e.target.files[0];
let param = new FormData(); //创建form对象
param.append('file',file,file.name);//通过append向form对象添加数据
param.append('chunk','0');//添加form表单中其他数据
console.log(param.get('file')); //FormData私有类对象,访问不到,可以通过get判断值是否传进去
let config = {
headers:{'Content-Type':'multipart/form-data'}
}; //添加请求头
this.axios.post('http://upload.qiniu.com/',param,config)
.then(response=>{
console.log(response.data);
})
}
以下部分是扩展
vue开发环境下,上传图片到七牛
最近着手的约能人项目,需要上传图片到七牛,但是感觉只是简单的上传图片还需要引七牛的js,太麻烦了,就自己一切从简。实现逻辑:获取后台返回的七牛token,然后axios的post请求,发送form数据到七牛。
七牛的token是其平台封装好的,直接在自己服务器配置就能获取到 在其官网上可以找到直接能用的代码 ,在七牛平台获取到后,返回给前台直接拿就好了
以下是直接上传图片到七牛,不需要安装七牛乱七八糟的js,只需要通过七牛的form表单上传就行了。
update(e){
let file = e.target.files[0];
let d = new Date();
let type = file.name.split('.');
let tokenParem = {
'putPolicy':'{\"name\":\"$(fname)\",\"size\":\"$(fsize)\",\"w\":\"$(imageInfo.width)\",\"h\":\"$(imageInfo.height)\",\"hash\":\"$(etag)\"}',
'key':'orderReview/'+d.getFullYear()+'/'+(d.getMonth()+1)+'/'+d.getDate()+'/'+d.valueOf()+'.'+type[type.length-1],
'bucket':this.domain,//七牛的地址,这个是你自己配置的(变量)
};
let param = new FormData(); //创建form对象
param.append('chunk','0');//断点传输
param.append('chunks','1');
param.append('file',file,file.name)
console.log(param.get('file')); //FormData私有类对象,访问不到,可以通过get判断值是否传进去
let config = {
headers:{'Content-Type':'multipart/form-data'}
};
//先从自己的服务端拿到token
this.axios.post(api.uploadToken,qs.stringify(tokenParem))
.then(response=>{
this.token = response.data.uploadToken;
param.append('token',this.token);
if(this.images.length>8){
alert('不能超过9张');
return;
}
this.uploading(param,config,file.name);//然后将参数上传七牛
return;
})
},
uploading(param,config,pathName){
this.axios.post('http://upload.qiniu.com/',param,config)
.then(response=>{
console.log(response.data);
let localArr = this.images.map((val,index,arr)=>{
return arr[index].localSrc;
})
if(!~localArr.indexOf(pathName)){
this.images.push({'src':this.showUrl+response.data.key,'localSrc':pathName});
}else{
alert('已上传该图片');
}
})
},
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue七牛上传图片
# VUE
# axios上传图片
# vuejs上传图片到七牛
# Vue使用axios图片上传遇到的问题
# vue实现axios图片上传功能
# 基于vue+axios+lrz.js微信端图片压缩上传方法
# vue axios 表单提交上传图片的实例
# vue项目中使用axios上传图片等文件操作
# vue+axios实现图片上传识别人脸的示例代码
# 表单
# 上传图片
# 服务端
# 可以通过
# 上传
# 自己的
# 就能
# 两种
# 你自己
# 没办法
# 还需要
# 只需要
# 可以实现
# 发送到
# 设置为
# 转换成
# 可以找到
# 绑定
# 不能超过
# 多条
相关文章:
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
linux top下的 minerd 木马清除方法
如何快速上传建站程序避免常见错误?
建站之星价格显示格式升级,你的预算足够吗?
常州企业建站如何选择最佳模板?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
建站之星如何取消后台验证码生成?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
python的本地网站制作,如何创建本地站点?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何在Windows服务器上快速搭建网站?
已有域名和空间如何搭建网站?
魔方云NAT建站如何实现端口转发?
黑客如何通过漏洞一步步攻陷网站服务器?
Android自定义listview布局实现上拉加载下拉刷新功能
c# await 一个已经完成的Task会发生什么
建站主机CVM配置优化、SEO策略与性能提升指南
建站之星后台密码遗忘?如何快速找回?
开心动漫网站制作软件下载,十分开心动画为何停播?
子杰智能建站系统|零代码开发与AI生成SEO优化指南
如何快速生成ASP一键建站模板并优化安全性?
简单实现Android验证码
javascript中的try catch异常捕获机制用法分析
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
深入理解Android中的xmlns:tools属性
高防服务器租用首荐平台,企业级优惠套餐快速部署
建站主机与虚拟主机有何区别?如何选择最优方案?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
音乐网站服务器如何优化API响应速度?
建站之星多图banner生成与模板自定义指南
c# 服务器GC和工作站GC的区别和设置
建站之星下载版如何获取与安装?
,怎么在广州志愿者网站注册?
c# 在高并发场景下,委托和接口调用的性能对比
Swift中swift中的switch 语句
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
建站之星备案流程有哪些注意事项?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
长沙企业网站制作哪家好,长沙水业集团官方网站?
,想在网上投简历,哪几个网站比较好?
如何通过西部建站助手安装IIS服务器?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
建站之星客服服务时间及联系方式如何?
5种Android数据存储方式汇总
高防服务器租用指南:配置选择与快速部署攻略
定制建站流程解析:需求评估与SEO优化功能开发指南
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
*请认真填写需求信息,我们会在24小时内与您取得联系。