Vue中为了减少自己服务器的内存,可以通过第三方云服务器来存储地址,把图片的地址存到自己的服务器上
这个案例是用element-ui组件库中的upload组件
只是针对于elment-ui组件库有效,如果使用其他的组件库,需要做更改
<!-- show-file-list 是否显示文件名字
before-upload 上传之前的回调函数
on-success 上传成功的回调函数
http-request 自定义上传,覆盖默认的上传行为 -->
<el-upload
class="avatar-uploader"
action="#"
:show-file-list="false"
:on-success="handleAvatarSuccess"
:before-upload="beforeAvatarUpload"
:http-request="upload"
>
<!-- <img v-if="imageUrl" :src="imageUrl" class="avatar"> -->
<img v-if="value" :src="value" class="avatar">
<i v-else class="el-icon-plus avatar-uploader-icon" />
<!-- 进度条 -->
<el-progress v-show="showProgress" :percentage="percent" />
</el-upload>
第一步先下载包cos-js-sdk-v5
const COS = require('cos-js-sdk-v5')
// 填写自己腾讯云cos中的key和id (密钥)
const cos = new COS({
SecretId: 'AKIDWLuDHAsKxQecJlvmQIJsAB0a9RrwqbeR', // 身份识别ID
SecretKey: 'xxx' // 身份秘钥
})
第二步在methods中定义一个方法
if (res.file) {
// 当有图片的时候,控制进度条的显示
this.showProgress = true
console.log('子组件新图片的地址是', this.value)
// 执行上传操作
cos.putObject({
Bucket: 'renzi-image-1305723434', /* 存储桶 */
Region: 'ap-beijing', /* 存储桶所在地域,必须字段 */
Key: res.file.name, /* 文件名 */
StorageClass: 'STANDARD', // 上传模式, 标准模式
Body: res.file, // 上传文件对象
onProgress: (progressData) => { // 上传进度
console.log(JSON.stringify(progressData))
this.percent = progressData.percent * 100 // 为什么要乘以100呢,因为进度条用的组件elmentui要求的
}
}, (err, data) => {
if (err) {
this.$message.error(err.message)
} else {
// 上传成功之后
if (data.statusCode === 200) {
// this.imageUrl = `https:${data.Location}`
this.$emit('input', `https:${data.Location}`)
this.$message.success('操作成功')
}
}
this.showProgress = false
})
}