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}`;
}
相关推荐
LuckySusu3 分钟前
【vue篇】Vue 数组响应式揭秘:如何让 push 也能更新视图?
前端·vue.js
LuckySusu4 分钟前
【vue篇】Vue 性能优化神器:keep-alive 深度解析与实战指南
前端·vue.js
LuckySusu4 分钟前
【vue篇】Vue 核心机制揭秘:为什么组件的 data 必须是函数?
前端·vue.js
LuckySusu6 分钟前
【vue篇】Vue 响应式陷阱:动态添加对象属性为何不更新?如何破解?
前端·vue.js
LuckySusu6 分钟前
【vue篇】Vue 异步更新之魂:$nextTick 原理与实战全解
前端·vue.js
LuckySusu6 分钟前
【vue篇】Vue 条件渲染终极对决:v-if vs v-show 深度解析
前端·vue.js
LuckySusu7 分钟前
【vue篇】单页 vs 多页:Vue 应用架构的终极对决
前端·vue.js
LuckySusu8 分钟前
【vue篇】Vue 核心指令原理解析:v-if、v-show、v-html 的底层奥秘
前端·vue.js
LuckySusu8 分钟前
【vue篇】Vue 进阶指南:如何在自定义组件中完美使用 v-model
前端·vue.js
LuckySusu9 分钟前
【vue篇】Vue v-model 深度解析:从表单到组件的双向绑定之谜
前端·vue.js