vue 借用element-ui实现头像上传 axios发送请求

简介: vue 借用element-ui实现头像上传 axios发送请求

<!-- 上传组件 -->


   <!-- 总结一下:


   action  写图片上传请求的路径 去路径哈


   show-file-list就是当你上传时,是否会显示出上传的是哪一个图片,一般为false


   handleAvatarSuccess它是成功的回调


   beforeAvatarUpload:上传之前做的一些事情


在本页面中你不点击按钮  图片也会显示出来  element-ui中的上传组件 在action时,写了上传地址,当你选择好图片,就自动帮你上传了


<template>
  <div>
    <el-upload
      class="avatar-uploader"
      action="http://127.0.0.1:666/login/upload"
      :show-file-list="false"
      :on-success="handleAvatarSuccess"
      :before-upload="beforeAvatarUpload"
    >
      <img v-if="avatarUrl" :src="avatarUrl" class="avatar" />
      <i v-else class="el-icon-plus avatar-uploader-icon"></i>
    </el-upload>
     //在本页面中你不点击按钮  图片也会显示出来 
    <el-button @click="saveAvatar">获取图片请求</el-button>
    <!-- 图片回显示  比如它回显在顶部头像,我放在这里是方便演示-->
    <div class="avatar">
      <img width="100%" height="100%" :src="avatarUrl" alt />
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      avatarUrl: "http://127.0.0.1:8080/avatar.jpg" //默认头像
    };
  },
  methods: {
    // 上传成功的函数
    handleAvatarSuccess(res, file) {
      // 上传成功 回显图片
      this.avatarUrl = URL.createObjectURL(file.raw);
      console.log(URL.createObjectURL(file.raw));
    },
    // 上传之前的限制函数
    beforeAvatarUpload(file) {
      // 类型
      const isJPG = file.type === "image/jpeg";
      // 大小
      const isLt2M = file.size / 1024 / 1024 < 2;
      // 类型限制
      if (!isJPG) {
        this.$message.error("上传头像图片只能是 JPG 格式!");
      }
      // 大小限制
      if (!isLt2M) {
        this.$message.error("上传头像图片大小不能超过 2MB!");
      }
      return isJPG && isLt2M;
    },
    // 回去头像的请求
    getAvatar() {
      this.req
        .get("/login/getavatar")
        .then(response => {
          let data = response.data;
          this.avatarUrl =
            "http://127.0.0.1:666" + data[data.length - 1].imgUrl;
          // console.log(data[data.length - 1].imgUrl);
        })
        .catch(err => {
          console.log(err);
        });
    }
  },
  created() {
    // 获取头像
    this.getAvatar();
  }
};
</script>
<style lang="less" 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;
}
</style>
相关文章
|
资源调度 JavaScript 前端开发
vue封装请求
vue封装请求
81 0
|
存储 JavaScript
vue页面跳转取消上一个页面请求
本文介绍了在Vue中如何取消上一个页面的请求,以避免页面跳转时请求未完成导致的数据错误。核心方法是使用axios的请求拦截器设置请求的取消令牌(cancelToken),并在vuex中存储这些取消令牌的引用。当进行路由跳转时,通过路由守卫清除这些请求,达到取消上一个页面请求的目的。
464 2
|
8月前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
254 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口
|
JavaScript UED
以 Vue 3 项目为例,多个请求下如何全局封装 Loading 的展示与关闭?其中大有学问!
以 Vue 3 项目为例,多个请求下如何全局封装 Loading 的展示与关闭?其中大有学问!
|
JavaScript 开发者 UED
Vue.js组件库大对决:Element UI与Vuetify,开发者的罗密欧与朱丽叶!
【8月更文挑战第30天】Element UI和Vuetify是Vue.js开发中的热门组件库,前者简洁高效,后者遵循Material Design,国际化程度高。两者均提供丰富的组件支持,但Vuetify组件更多样,设计更灵活;Element UI在性能和中文支持上更优。文档方面,Element UI更直观易懂,而Vuetify配置灵活但学习成本稍高。选择时需综合考虑项目需求、团队背景及设计风格,以达到最佳开发效果。
809 0
|
JavaScript
vue 发送请求时展示进度条——NProgress的简单使用
vue 发送请求时展示进度条——NProgress的简单使用
1158 0
|
JavaScript API
本地开发环境请求服务器接口跨域的问题(vue的问题)
本地开发环境请求服务器接口跨域的问题(vue的问题)
937 1
|
Web App开发 前端开发 JavaScript
Spring Boot整合 mybatisplus(后端) Vue+echarts+Element UI+axios(前端)---前后端项目实例demo
Spring Boot整合 mybatisplus(后端) Vue+echarts+Element UI+axios(前端)---前后端项目实例demo
620 1

热门文章

最新文章