el-upload上传图片到七牛云或阿里云

(1)绑定上传地址,上传数据对象

html 复制代码
<el-upload class="upload-demo" :action="uploadUrl" :data="uploadData"
 :on-success="handleSuccess" :file-list="[]" :show-file-list="false" :limit="1">
</el-upload>

(2)定义数据

javascript 复制代码
// 商户的driver
driver: null,
// 图片上传的路径
uploadUrl: '',
// 上传图片的携带的信息
uploadData: {},
// 图片的链接头部分
cdn: ""

(3)定义方法

图片的路径就是图片头加上返回的key

javascript 复制代码
/**
 * 获取获取商户的driver
 */
async getDriver() {
   let res = await customerService.getDriver();
   if (res.code == 200) {
       this.driver = res.data.cdn_driver;
       this.cdn = res.data.cdn;
       this.driver ? this.getUploadToken() : "";
   }
},
/**
 * 上传图片获取token
 */
async getUploadToken() {
   let params = {
      driver: this.driver
   };
   let res = await customerService.getUploadToken(params);
   if (res.code == 200) {
      switch (this.driver) {
        case 'oss':
            this.uploadData = {
                OSSAccessKeyId: res.data.accessid,
                policy: res.data.policy,
                success_action_status: '200',
                callback: res.data.callback,
                signature: res.data.signature,
                dir: res.data.dir
            };
            this.uploadUrl = res.data.host;
            break;
         case 'qiniu':
            this.uploadData = {
                dir: '',
                token: res.data.token
             };
            this.uploadUrl = "https://up.qiniup.com";
       }
   }
},
/**
 * 上传图片成功
 */
handleSuccess(res, file, fileList) {
   // 图片的路径就是图片头加上返回的key
   let imgUrl = `${this.cdn}${res.key}`;
}
相关推荐
青灯文案1几秒前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_748254885 分钟前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.17 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营21 分钟前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端1 小时前
0基础学前端-----CSS DAY9
前端·css
joan_851 小时前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
m0_748236111 小时前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
Watermelo6172 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
m0_748248942 小时前
HTML5系列(11)-- Web 无障碍开发指南
前端·html·html5