一. 安装依赖
xlsx –> excel处理库
excel的导入导出都是依赖于 js-xlsx 来实现的 –> 在此依赖包的基础上封装了便于导出数据的Export2Excel.js文件
二. 创建文件, 放入UploadExcel
在src路径下创建组件–> UploadExcel/index.vue
<template>
<div>
<!-- :on-success="handleAvatarSuccess"
:before-upload="beforeAvatarUpload" -->
<el-upload
class="avatar-uploader"
action="#"
:show-file-list="false"
:http-request="upload"
>
<img v-if="value" :src="value" class="avatar">
<i v-else class="el-icon-plus avatar-uploader-icon" />
<el-progress v-show="isShowProgress" type="circle" :percentage="percentage" :width="178" class="progress" />
</el-upload>
</div>
</template>
<script>
// 实例化cos对象
const COS = require('cos-js-sdk-v5')
// 填写自己腾讯云cos中的key和id (密钥)
const cos = new COS({
SecretId: 'AKID3wZw2sRjlW0D9oCJAk23nH2WjgMkrpXy', // 身份识别ID
SecretKey: 'B4g15sOdcJkunPkob6KIzPXP0LPBhwua' // 身份秘钥
})
export default {
name: 'UploadImg',
props: {
value: {
type: String,
default: ''
}
},
data() {
return {
isShowProgress: false,
percentage: 0
}
},
methods: {
upload(res) {
if (res.file) {
this.isShowProgress = true
cos.putObject({
Bucket: 'rlzy-one-1306404223', /* 存储桶 */
Region: 'ap-beijing', /* 存储桶所在地域,必须字段 */
Key: res.file.name, /* 文件名 */
StorageClass: 'STANDARD', // 上传模式, 标准模式
Body: res.file, // 上传文件对象
onProgress: (progressData) => {
console.log(JSON.stringify(progressData))
this.percentage = progressData.percent * 100
if (progressData.percent === 1) {
this.isShowProgress = false
}
}
}, (err, data) => {
console.log(err || data)
if (data.statusCode === 200) {
const urlImg = `https:${data.Location}`
this.$emit('input', urlImg)
}
})
}
}
// handleAvatarSuccess(res, file) {
// this.imageUrl = URL.createObjectURL(file.raw)
// },
// beforeAvatarUpload(file) {
// const isPNG = file.type === 'image/png'
// const isLt2M = file.size / 1024 / 1024 < 2
// if (!isPNG) {
// this.$message.error('上传头像图片只能是 PNG 格式!')
// }
// if (!isLt2M) {
// this.$message.error('上传头像图片大小不能超过 2MB!')
// }
// return isPNG && isLt2M
// }
}
}
</script>
<style>
.avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
}
.avatar-uploader .el-upload:hover {
border-color: #409eff;
}
.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 178px;
height: 178px;
line-height: 178px;
text-align: center;
}
.avatar {
width: 178px;
height: 178px;
display: block;
}
.progress {
position: absolute;
top: 1px;
left: 1px
}
</style>
复制代码
三. 使用该组件,灵活应用该组件上的通信事件
// 伪代码
import uploadExcel from 'xxx/UploadExcel'
// 使用组件
<upload-excel :on-success="handleSuccess" :before-upload="handleUpload" />
复制代码
- beforeUpload: 可以在上传之前对数据做一些条件限制,判断 –》 参数就是当前传入的文件
beforeUpload(file) {
const isLt1M = file.size / 1024 / 1024 < 1
if (isLt1M) {
return true
}
this.$message({
message: 'Please do not upload files larger than 1m in size.',
type: 'warning'
})
return false
}
复制代码
- onSuccess: 解析成功触发的回调函数,返回表格的表头和内容
handleSuccess({ results, header }) {
this.tableData = results // 内容
this.tableHeader = header // 表头
}
复制代码
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END