VUE之图片Base64编码使用ElementUI组件上传


Posted in Vue.js onApril 09, 2022

ElementUI上传Base64编码后的图片

自我认为ElementUI还是一个很不错的写手机端的组件,所以这次做小项目的时候就用了ElementUI的Upload组件来实现图片的上传,不过ElementUI组件的上传图片更易于实现图片以File文件的形式实现,但是这次我需要把图片转换为base64编码来实现图片的上传。

安装ElementUI

npm i element-ui -S

按需引入(当然如果需要你也可以全部引入)

import { Upload } from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(Upload);

上传实现 

<template>
    <div>
       <el-upload
          class="avatar-uploader"
          :action="actionUrl"
          :show-file-list="false"
          :on-change="getFile">
          <img v-if="imageUrl" ref="phoUrl" :src="imageUrl" class="avatar">
          <i v-else class="el-icon-plus avatar-uploader-icon"></i>
        </el-upload>
    </div>
</template>
<script>
import {Toast} from "mint-ui";
export default {
   data() {
      return {
       actionUrl:'',
       imageUrl:'', //上传图片
      };
    },
    methods: {
     getBase64(file){  //把图片转成base64编码
         return new Promise(function(resolve,reject){
             let reader=new FileReader();
             let imgResult="";
             reader.readAsDataURL(file);
             reader.onload=function(){
                 imgResult=reader.result;
             };
             reader.onerror=function(error){
                 reject(error);
             };
             reader.onloadend=function(){
                 resolve(imgResult);
             }
         })
     },
     getFile(file,fileList){  //上传头像
       this.getBase64(file.raw).then(res=>{
           this.$http.post('home/ImgUpload',{"img":res}).then(result=>{
               if(result.body.status===200){
                   this.imageUrl=result.body.data;
               }else{
                   Toast('图片上传失败');
               }
           })
       })
     }
    }
}
</script>
<style>
  .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    width:101px;
    height:101px;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader .el-upload .el-upload__input{
      display: none;
  }
  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 100px;
    height: 100px;
    line-height: 100px;
    text-align: center;
  }
  .avatar {
    width: 100px;
    height: 100px;
    display: block;
  }
</style>

ElementUI把上传的图片转为Base64

使用组件,然后on-change绑定一个方法来获取文件信息,auto-upload设置为false即可 

 <el-upload action='' :on-change="getFile" :limit="1" list-type="picture" :auto-upload="false">
            <el-button size="small" type="primary">选择图片上传,最多上传一张图片</el-button>
          </el-upload>

定义methods方法,当上传文件就会触发绑定的函数,然后文件的内容就会绑定到函数的参数里面,这样用file.raw就可以获取文件的内容了。

  getFile(file, fileList) {
     console.log(file.raw)
    },

然后自定义一个方法,用来把图片内容转为base64格式,imgResult就是base64格式的内容了。转为base64字符串要调用h5特性中的FileReader这个api,但是这个api不能return,所以用promise封装一下。

 getBase64(file) {
      return new Promise(function(resolve, reject) {
        let reader = new FileReader();
        let imgResult = "";
        reader.readAsDataURL(file);
        reader.onload = function() {
          imgResult = reader.result;
        };
        reader.onerror = function(error) {
          reject(error);
        };
        reader.onloadend = function() {
          resolve(imgResult);
        };
      });
    },

最后调用一下

 getFile(file, fileList) {    
      this.getBase64(file.raw).then(res => {
      console.log(res)
      });
    },

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
vue+iview实现分页及查询功能
Nov 17 Vue.js
vue 基于abstract 路由模式 实现页面内嵌的示例代码
Dec 14 Vue.js
vue 实现图片懒加载功能
Dec 31 Vue.js
如何在VUE中使用vue-awesome-swiper
Jan 04 Vue.js
如何在 Vue 表单中处理图片
Jan 26 Vue.js
Vue 事件的$event参数=事件的值案例
Jan 29 Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 Vue.js
vue项目两种方式实现竖向表格的思路分析
Apr 28 Vue.js
Vue Element-ui表单校验规则实现
Jul 09 Vue.js
如何优化vue打包文件过大
Apr 13 Vue.js
vue动态绑定style样式
Apr 20 Vue.js
vue如何在data中引入图片的正确路径
Jun 05 Vue.js
vue如何实现关闭对话框后刷新列表
Apr 08 #Vue.js
vue实现列表垂直无缝滚动
Apr 08 #Vue.js
vue3引入highlight.js进行代码高亮的方法实例
vue中的可拖拽宽度div的实现示例
vue 实现弹窗关闭后刷新效果
Apr 08 #Vue.js
vue中this.$http.post()跨域和请求参数丢失的解决
Apr 08 #Vue.js
vue实现书本翻页动画效果实例详解
Apr 08 #Vue.js
You might like
Laravel中unique和exists验证规则的优化详解
2018/01/28 PHP
认识延迟时间为0的setTimeout
2008/05/16 Javascript
javascript for循环设法提高性能
2010/02/24 Javascript
基于jQuery的左右滚动实现代码
2010/12/03 Javascript
JS控制日期显示的小例子
2013/11/23 Javascript
基于JQuery实现滚动到页面底端时自动加载更多信息
2014/01/31 Javascript
jquery获取tr并更改tr内容示例代码
2014/02/13 Javascript
解决js下referer兼容各大浏览器的方法
2014/11/03 Javascript
Javascript实现鼠标框选操作  不是点击选取
2016/04/14 Javascript
纯JS代码实现气泡效果
2016/05/04 Javascript
bootstrap布局中input输入框右侧图标点击功能
2016/05/16 Javascript
微信小程序 Video API实例详解
2016/10/02 Javascript
jQuery利用sort对DOM元素进行排序操作
2016/11/07 Javascript
servlet+jquery实现文件上传进度条示例代码
2017/01/25 Javascript
canvas绘制七巧板
2017/02/03 Javascript
JavaScript的for循环中嵌套一个点击事件的问题解决
2017/03/03 Javascript
原生JavaScript实现Tooltip浮动提示框特效
2017/03/07 Javascript
在bootstrap中实现轮播图实例代码
2017/06/11 Javascript
详解Angular 中 ngOnInit 和 constructor 使用场景
2017/06/22 Javascript
element ui table 增加筛选的方法示例
2018/11/02 Javascript
Vue中用props给data赋初始值遇到的问题解决
2018/11/27 Javascript
小程序hover-class点击态效果实现
2019/02/26 Javascript
[03:24]DOTA2超级联赛专访hao 大翻盘就是逆袭
2013/05/24 DOTA
python抓取网页图片并放到指定文件夹
2014/04/24 Python
Python中使用item()方法遍历字典的例子
2014/08/26 Python
简单的编程0基础下Python入门指引
2015/04/01 Python
在Python中实现贪婪排名算法的教程
2015/04/17 Python
解决pip install的时候报错timed out的问题
2018/06/12 Python
python随机模块random使用方法详解
2020/02/14 Python
Python实现读取并写入Excel文件过程解析
2020/05/27 Python
需要知道的CSS3动画技术
2010/01/01 HTML / CSS
中学生差生评语
2014/01/30 职场文书
学校领导班子对照检查材料
2014/08/28 职场文书
2015年感恩母亲节的演讲稿
2015/03/18 职场文书
Python实现DBSCAN聚类算法并样例测试
2021/06/22 Python
Pandas数据结构之Series的使用
2022/03/31 Python