VUE axios上传图片到七牛的实例代码
发布时间 - 2026-01-11 02:33:31 点击率:次浏览器上传图片到服务端,我用过两种方法:

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实现图片上传识别人脸的示例代码
# 表单
# 上传图片
# 服务端
# 可以通过
# 上传
# 自己的
# 就能
# 两种
# 你自己
# 没办法
# 还需要
# 只需要
# 可以实现
# 发送到
# 设置为
# 转换成
# 可以找到
# 绑定
# 不能超过
# 多条
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
VIVO手机上del键无效OnKeyListener不响应的原因及解决方法
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
高端云建站费用究竟需要多少预算?
Python数据仓库与ETL构建实战_Airflow调度流程详解
Laravel如何使用Blade模板引擎?(完整语法和示例)
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
北京网站制作的公司有哪些,北京白云观官方网站?
Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
MySQL查询结果复制到新表的方法(更新、插入)
PythonWeb开发入门教程_Flask快速构建Web应用
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
打造顶配客厅影院,这份100寸电视推荐名单请查收
如何用AI帮你把自己的生活经历写成一个有趣的故事?
Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
独立制作一个网站多少钱,建立网站需要花多少钱?
Android Socket接口实现即时通讯实例代码
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
如何用好域名打造高点击率的自主建站?
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
怎么用AI帮你为初创公司进行市场定位分析?
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
如何用虚拟主机快速搭建网站?详细步骤解析
敲碗10年!Mac系列传将迎来「触控与联网」双革新
百度浏览器如何管理插件 百度浏览器插件管理方法
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
微信小程序 配置文件详细介绍
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
简单实现Android验证码
详解MySQL数据库的安装与密码配置
如何利用DOS批处理实现定时关机操作详解
如何快速搭建虚拟主机网站?新手必看指南
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
如何正确选择百度移动适配建站域名?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何用搬瓦工VPS快速搭建个人网站?
Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
php打包exe后无法访问网络共享_共享权限设置方法【教程】
如何在IIS中新建站点并解决端口绑定冲突?
上一篇:cad连续标注怎么使用
下一篇:ubuntu的基本命令有哪些
上一篇:cad连续标注怎么使用
下一篇:ubuntu的基本命令有哪些

