图片上传组件

图片上传组件element-ui
实列代码如下:

export function userAvatar(fileFormData){//上传用户头像
    return request({
        url: `/users/avatar`,
        method: 'POST',
        headers: {
            'Content-Type': 'multipart/form-data'
            },
        data:fileFormData
      })
}
export function getUserAvatar(){//获取用户头像
    return request({
        url: `/users/avatar`,
        method: 'get',
        responseType: 'arraybuffer',
      })
}
<template>
    <div>
        <el-upload
            class="avatar-uploader"
            :headers="myHeader"
            action=""
            :http-request="upLoad"
            :show-file-list="false"
            :on-success="handleAvatarSuccess"
            :before-upload="beforeAvatarUpload"
        >
            <img v-if="imageUrl" :src="imageUrl" class="userpic" />
            <i v-else class="el-icon-plus avatar-uploader-icon"></i>
        </el-upload>
    </div>
</template>

<script>
import { getUserAvatar, userAvatar } from "@/api/system/user";
export default {
    computed: {
        myHeader() {
            return {
                authToken: window.sessionStorage.getItem("authToken")
            };
        }
    },
    created() {
        this.handleAvatarSuccess();
    },
    data() {
        return {
            imageUrl: null
        };
    },
    methods: {
        upLoad(file) {
            const formData = new FormData();
            formData.append("file", file.file);
            userAvatar(formData)
                .then(res => {
                    // console.log("上传图片接口-数据", res);
                    this.handleAvatarSuccess();
                })
                .catch(err => {
                    this.$message.error("上传失败,请重新上传");
                    console.log("报错", err);
                });
        },
        handleAvatarSuccess() {
            getUserAvatar()
                .then(res => {
                    //获取用户头像信息
                    return (
                        "data:image/png;base64," +
                        btoa(
                            new Uint8Array(res.data).reduce(
                                (data, byte) =>
                                    data + String.fromCharCode(byte),
                                ""
                            )
                        )
                    );
                })
                .then(data => {
                    this.imageUrl = data || "";
                });
        },
        beforeAvatarUpload(file) {
            const isJPG = file.type === "image/jpeg";
            const isPNG = file.type === "image/png";
            const isLt2M = file.size / 1024 < 65;//图片大小不能超过65k

            if (!isJPG && !isPNG) {
                this.$message.error("上传头像图片只能是 JPG/PNG 格式!");
            }
            if (!isLt2M) {
                this.$message.error("上传头像图片大小不能超过 65k!");
            }
            // return isJPG && isLt2M;
            return isLt2M;
        }
    }
};
</script>

<style scoped>
.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;
}
.userpic {
    width: 100px;
    height: 100px;
    margin-left: 25px;
    border-radius: 50px;
    background-color: #474747;
}
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值