vue自定义上传头像组件功能

 更新时间:2024年01月17日 15:23:35   作者:@mimin  
这篇文章主要介绍了vue自定义上传头像组件功能,介绍了与一般上传组件的区别,通过实例代码介绍了上传图片组件的方法,需要的朋友可以参考下

1.展示效果

 1.1 效果图

 以上是没有上传的页面,以下是上传后鼠标放上去的效果

1.2 效果图

2.与一般上传组件的区别

 与饿了么上传组件主要区别在于只会在一个图像占位符上操作

3.上传图片组件

以下是上传图片组件代码内容

<template>
  <div class="account-avatar">
    <el-upload class="avatar-uploader" :action="uploadFileUrl" :show-file-list="false" :headers="headers" :on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload">
        <img v-if="imageUrl" :src="imageUrl" class="avatar" />
        <i v-else class="el-icon-plus avatar-uploader-icon"></i>
        <i v-if="imageUrl" class="el-icon-plus avatar-uploader-icon iconClass"></i>
    </el-upload>
  </div>
</template>
<script>
import { getToken } from "@/utils/auth";
export default {
  props: {
    imgUrl: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      certificateImg: [],
      imageUrl: '',
      uploadFileUrl: process.env.VUE_APP_BASE_API + "/common/upload", // 上传的图片服务器地址
          headers: {
              Authorization: "Bearer " + getToken()
          },
    }
  },
  mounted() {
    this.imageUrl = this.imgUrl
  },
  methods: {
    handleAvatarSuccess(res, file) {
      const fileName = file.name
      this.imageUrl =  file.response.url
      this.$emit('fileUrl', this.imageUrl)
    },
    beforeAvatarUpload(file) {
      const isJPG = file.type === 'image/jpeg'
      const isPNG = file.type === 'image/png'
      const isLt2M = file.size / 1024 / 1024 < 2
      if (!isJPG && !isPNG) {
        this.$message.error('上传头像图片只能是 JPG或PNG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      return isJPG || (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;
}
.iconClass{
  position: absolute;
  top: 0px;
  left: 0px;
  opacity: 0;
}
.iconClass:hover{
  color: #fbfbfb;
  position: absolute;
  top: 0px;
  left: 0px;
  opacity: 0.5;
  background-color: #7a7979;
}
</style>

4.引用组件

引用组件内容代码

//vue中template部分
<el-form-item prop="issueCardPic" label-width="0">
      <ImagesUpdate :imgUrl="form.issueCardPic" class="avatar-uploader"
       @fileUrl="avatorUPload"></ImagesUpdate>
</el-form-item>
//vue中script部分
import ImagesUpdate from "@/views/components/imagesUpdate"; //附件组件的地址
export default {
    data(){
        return{
            form:{}
            ...
            }
       },
    components:{
        ImagesUpdate
    },
    methods:{
        avatorUPload(){
        //上传后将地址塞入表单字段
            this.$set(this.form, 'issueCardPic', val)
            },
       }
}

到此这篇关于vue自定义上传头像组件的文章就介绍到这了,更多相关vue自定义上传头像组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue项目部署到非根目录下的问题及解决

    vue项目部署到非根目录下的问题及解决

    这篇文章主要介绍了vue项目部署到非根目录下的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • vue实现pdf文件发送到邮箱功能的示例代码

    vue实现pdf文件发送到邮箱功能的示例代码

    这篇文章主要介绍了vue实现pdf文件发送到邮箱功能,实现代码包括对邮箱格式内容是否为空的验证方法,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • vue执行配置选项npm run serve的本质图文详解

    vue执行配置选项npm run serve的本质图文详解

    本地开发一般通过执行npm run serve命令来启动项目,那这行命令到底存在什么魔法?下面这篇文章主要给大家介绍了关于vue执行配置选项npm run serve的本质的相关资料,需要的朋友可以参考下
    2023-05-05
  • Vue实现摇一摇功能(兼容ios13.3以上)

    Vue实现摇一摇功能(兼容ios13.3以上)

    这篇文章主要为大家详细介绍了Vue实现摇一摇功能,兼容ios13.3以上,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • vue项目上传Github预览的实现示例

    vue项目上传Github预览的实现示例

    这篇文章主要介绍了vue项目上传Github预览的实现示例,在完成Vue项目以后,在上传到github并实现预览
    2018-11-11
  • Vue中如何引用公共方法和公共组件

    Vue中如何引用公共方法和公共组件

    这篇文章主要介绍了Vue中如何引用公共方法和公共组件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • vue从零实现一个消息通知组件的方法详解

    vue从零实现一个消息通知组件的方法详解

    这篇文章主要介绍了vue从零实现一个消息通知组件的方法,结合实例形式分析了vue实现消息通知组件的具体原理、实现步骤、与相关操作技巧,需要的朋友可以参考下
    2020-03-03
  • vue的图片需要用require的方式进行引入问题

    vue的图片需要用require的方式进行引入问题

    这篇文章主要介绍了vue的图片需要用require的方式进行引入问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • 详解无限滚动插件vue-infinite-scroll源码解析

    详解无限滚动插件vue-infinite-scroll源码解析

    这篇文章主要介绍了详解无限滚动插件vue-infinite-scroll源码解析,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-05-05
  • 基于Electron+Vite快速构建Vue3桌面应用

    基于Electron+Vite快速构建Vue3桌面应用

    这篇文章主要介绍了如何基于Electron和Vite快速构建Vue3桌面应用,本文主要技术栈就是Vue3、vite、Electron,文中有详细的代码示例,需要的朋友可以参考下
    2023-07-07

最新评论