中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue如何實現文件上傳

發布時間:2022-04-11 10:35:38 來源:億速云 閱讀:1861 作者:iii 欄目:開發技術

本篇內容主要講解“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如何實現文件上傳”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

玉门市| 兴和县| 南江县| 鹤庆县| 鄯善县| 湄潭县| 昭通市| 黄山市| 和平区| 连城县| 五寨县| 崇阳县| 敦煌市| 菏泽市| 上林县| 和林格尔县| 公主岭市| 资中县| 阿拉善左旗| 柯坪县| 宁海县| 渭南市| 藁城市| 秀山| 吴桥县| 普兰店市| 兴化市| 崇文区| 运城市| 丹东市| 鲁甸县| 新安县| 芮城县| 沙田区| 大埔县| 西乌珠穆沁旗| 龙游县| 彩票| 昌邑市| 夏邑县| 江孜县|