文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue如何实现文件上传

2023-06-29 23:00

关注

本篇内容主要讲解“vue如何实现文件上传”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue如何实现文件上传”吧!

1、使用elementUI的 el-upload插件进行上传。

html:

<el-upload          ref="avatar-uploader"          class="avatar-uploader"          :show-file-list="false"          :auto-upload="false"          action          :on-change="handleChange"        >          <img v-if="AddSubmenuData.imageUrl" :src="AddSubmenuData.imageUrl" class="avatar">          <i v-else class="el-icon-plus avatar-uploader-icon"></i>        </el-upload>

js:

data() {      return {        AddSubmenuData:{          id:"",          pid:"",          funType:1,          name:"",          sort:"",          SystemCoding:"",          remarks:"",          imageUrl: ''        },      };  },  methods: {      // 获取图片信息并转成base64      handleChange(file, fileList){       let reader = new FileReader();        let fileResult = "";        reader.readAsDataURL(file.raw);        reader.onload = function() {          fileResult = reader.result;        };        reader.onloadend = function() {           this.AddSubmenuData.imageUrl = fileResult        };      }  }

css:

 /deep/  .avatar-uploader .el-upload {      border: 1px dashed #d9d9d9;      border-radius: 6px;      cursor: pointer;      position: relative;      overflow: hidden;      margin-left: 80px;      margin-bottom: 22px;    }    .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;    }

效果图:

vue如何实现文件上传

vue如何实现文件上传

2、使用input进行上传。

1)、html

首先input的type属性要改成file,如果需求是点击按钮在上传文件。可以给input加一个ref=“fileInput”,然后通过点击按钮调用input的事件:@click="$refs.fileInput.click()".

<div class="el-button--primary el-button" @click="$refs.fileInput.click()">   <input type="file" ref="fileInput" accept="*" @change="getFile" >   <img src="../../assets/Infrastructure/xz.png" />添加</div>

2)、js

获取文件后就可以进行数据处理并调用接口。因为有些时候,上传文件有些是重复的,再次调用方法就是失效,所以,可以在每次上传完之后清除之前上传的文件,这样即使文件相同,也可以重复调用方法。this.$refs.fileInput.value=&rsquo;&rsquo;

// 获取文件数据  getFile(event) {//这就是你上传的文件       event.target.files[0]              let formFile = new FormData();        formFile.append("file", event.target.files[0]);        formFile.append("apply_info_id", this.RndNum(12));        formFile.append("file_type", '');        //调用接口        file_upload(formFile).then(res => {          this.addInformation.addPoupTableData.data.push({name:res.data.name,id:res.data.id,size:(event.target.files[0].size/1024).toFixed(0) + "kb",path:res.data.path})          //调用接口后清除文件          this.$refs.fileInput.value=''        }) },

到此,相信大家对“vue如何实现文件上传”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯