日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue3使用el-upload上傳文件示例詳解

瀏覽:244日期:2022-06-01 10:30:37
目錄
  • el-upload上傳文件
    • 屬性
    • 方法
  • 上傳圖片的實現(xiàn)
    • 存在的坑
      • 問題1
      • 問題2
      • 問題3

    el-upload上傳文件

    在項目開發(fā)的過程中上傳文件的需求是經(jīng)常會遇到的,這篇文章我們就詳細介紹使用elementplus中el-upload來上傳文件了。

    我們先來看一下el-upload可以配置哪些屬性和事件。

    屬性

    • action: 請求url
    • headers: 設(shè)置上傳的請求頭部
    • method: 設(shè)置上傳請求方法
    • multiple: 是否支持多選文件
    • data: 上傳時附帶的額外參數(shù)
    • name: 上傳的文件字段名
    • with-credentials: 支持發(fā)送cookie憑證信息

    以上這些參數(shù)都是采用action的默認方式請求時使用的,如果我們使用自定義的請求方法,這些屬性基本上都不會使用到。

    • show-file-list: 是否顯示已上傳文件列表
    • drag: 是否啟用拖拽上傳
    • accept: 接受上傳的文件類型
    • on-preview: 點擊文件列表中已上傳文件時的鉤子
    • on-remove: 文件列表移除文件時的鉤子
    • on-success: 文件上傳成功時的鉤子
    • on-error: 文件上傳失敗時的鉤子
    • on-progress: 文件上傳時的鉤子
    • on-change: 文件狀態(tài)改變時的鉤子,添加,上傳成功和失敗都會被調(diào)用
    • on-exceed: 當超出限制時執(zhí)行的鉤子
    • before-upload: 文件上傳之前的鉤子,參數(shù)為上傳的文件, 若返回false或者返回 Promise 且被 reject,則停止上傳。
    • before-remove: 刪除文件之前的鉤子,參數(shù)為上傳的文件和文件列表, 若返回 false 或者返回 Promise 且被 reject,則停止刪除。
    • file-list/v-model:file-list: 默認上傳文件
    • list-type: 文件列表的類型,'text' | 'picture' | 'picture-card'。
    • auto-upload: 是否自動上傳文件
    • http-request: 覆蓋默認的 Xhr 行為,允許自行實現(xiàn)上傳文件的請求
    • disabled: 是否禁用上傳
    • limit: 允許上傳文件的最大數(shù)量

    方法

    • abort: 取消上傳請求
    • submit: 手動上傳文件列表
    • clearFiles: 清空已上傳的文件列表(該方法不支持在 before-upload 中調(diào)用)
    • handleStart: 手動選擇文件
    • handleRemove: 手動移除文件。 filerawFile 已被合并。

    上傳圖片的實現(xiàn)

    上傳圖片的時候我們一般都會重寫http請求,不使用默認的action去請求,因此action我們一般都會設(shè)置成‘#’。

    <template>
      <div>
        <el-upload
          action="#"
          :headers="headers"
          :list-type="listType"
          :http-request="uploadAction"
          :on-exceed="handleExceed"
          :on-remove="handleRemove"
          :before-upload="beforeUpload"
          :on-success="uploadSuccess"
          :on-error="uploadError"
          :on-progress="uploadProgress"
          :file-list="fileListCopy.data"
          ref="upload"
          :multiple="true"
          :limit="limit"
          :disabled="disabled"
          :data="paramData"
        >
        <el-icon><Plus /></el-icon>
        <template #file="{ file }">
          <div>
    <img :src="file.url" />
    <span>
      <span
       
        @click="handlePictureCardPreview(file)"
      >
        <el-icon><zoom-in /></el-icon>
      </span>
      <span
       
        @click="handleRemove(file)"
      >
        <el-icon><Delete /></el-icon>
      </span>
    </span>
          </div>
        </template>
        </el-upload>
        <el-dialog v-model="previewVisible">
          <img w-full :src="dialogImageUrl" />
        </el-dialog>
      </div>
    </template>
    <script>
    export default {
      name: "uploadImg"
    }
    </script>
    <script setup>
    import { Delete, Plus, ZoomIn } from "@element-plus/icons-vue";
    import { reactive, ref, defineProps, defineEmits, computed, getCurrentInstance } from "vue";
    import { ElMessage } from "element-plus";
    const props = defineProps({
      // 允許上傳文件件的最大數(shù)量
      limit:{
        type:Number
      },
      // 是否禁用上傳
      disabled:{
        type:Boolean,
        default:false
      },
      // 文件列表類型
      listType:{
        type:String,
        default:"picture-card"
      },
      // 上傳時攜帶的額外參數(shù)
      paramData: {
        type:String
      }
    });
    const emits = defineEmits([]);
    const cns = getCurrentInstance();
    const globObj = cns.appContext.config.globalProperties;
    const previewVisible = ref(false);
    const dialogImageUrl = ref("");
    const fileListCopy = reactive({
      data: []
    });
    const onece = ref(false);
    const myChangeFile = ref("");
    const changeFileIndex = ref(-1);
    const uploadImgArr = reactive({
      data: []
    });
    const headers = reactive({});
    // 預(yù)覽大圖
    const handlePictureCardPreview = (uploadFile) => {
      dialogImageUrl.value = uploadFile.url;
      previewVisible.value = true;
    };
    // 移除圖片
    const handleRemove = (file, fileList) => {
      console.log("handleRemove", handleRemove);
      console.log("file", file);
      console.log("fileList", fileList);
      fileListCopy.data = fileListCopy.data.filter(v => v.uid !== file.uid);
    };
    // 文件上傳數(shù)量限制
    const handleExceed = (files, fileList) => {
      if (props.limit) {
        ElMessage.error(`只能上傳${props.limit}張圖片`);
      }
      console.log("handleExceed", handleExceed);
      console.log("files", files);
      console.log("fileList", fileList);
    };
    // 上傳請求
    const uploadAction = (option) => {
      let formData = new FormData();
      const url = "";
      globObj.$axios({
        url: url,
        method: "post",
        transformRequest: [function(data, headers) {
          // 去除post請求默認的Content-Type
          delete headers["Content-Type"]
          return data
        }],
        data: formData,
        timeout: 300000
      }).then(res => {
        ElMessage.success("資產(chǎn)添加成功");
      }).catch((err) => {
        console.log(err);
      });
    }
    // 格式大小的限制
    const beforeUpload = (file) => {
      let isJPG = false,
      fileType = file.type.split("/")[0];
      if(file.type === "image/jpeg" || file.type === "image/png") {
        isJPG = true;
      } else {
        isJPG = false;
      }
      const isLt2M = file.size / 1024 / 1024;
      if (fileType != "image" || isLt2M > 2) {
        ElMessage.error("請上傳2M以內(nèi)的圖片文件!");
        return false
      }
      return true;
    };
    // 文件上傳成功時的鉤子
    const uploadSuccess = (response, file, fileList) => {
      // 上傳成功之后后臺返回的數(shù)據(jù)
      console.log("uploadSuccess", uploadSuccess);
    };
    const uploadProgress = (e, file, fileList) => {
      console.log("uploadProgress", uploadProgress)
    };
    const uploadError = (err, file, fileList) => {
      console.log("uploadError", uploadError);
    };
    </script>
    

    存在的坑

    一般上傳文件的話請求頭中的Content-Type: multipart/form-data;我們的需求中還需要設(shè)置文件的隨機數(shù),因此請求頭需要是這樣的Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

    下面是我遇到的問題。

    問題1

    設(shè)置了Content-Type: multipart/form-data;此時請求一直沒有隨機數(shù)boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

    如果設(shè)置了全局的content-type,會發(fā)現(xiàn)上傳接口設(shè)置multipart/form-data是不起作用的,因為沒有Boundary,所以上傳必定失敗,服務(wù)器500。

    然后嘗試手動添加Boundary,這次錯誤變400了

    問題2

    后來通過查詢資料,說不用設(shè)置Content-Type: multipart/form-data;只要參數(shù)是formData形式,瀏覽器就會自動將請求頭的Content-Type轉(zhuǎn)成Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

    但是我不設(shè)置的話就是默認的application/json。

    于是查閱資料發(fā)現(xiàn)axios的transformRequest屬性可以在向服務(wù)器發(fā)送請求數(shù)據(jù)之前修改請求數(shù)據(jù),因為我們的請求在默認的post請求方式時Content-Type的值是application/json,需要去掉默認的值,這樣瀏覽器就可以自動添加了。

      globObj.$axios({
        url: url,
        method: "post",
        transformRequest: [function(data, headers) {
          // 去除post請求默認的Content-Type
          delete headers["Content-Type"]
          return data
        }],
        data: formData,
        timeout: 300000
      }).then(res => {
        ElMessage.success("資產(chǎn)添加成功");
      }).catch((err) => {
        console.log(err);
      });
    

    問題3

    如果還要傳其他的參數(shù),其他的參數(shù)必須也要append進去,否則可能會報參數(shù)錯誤。

    const formData = new FormData();
    formData.append("file", file);
    // 其他參數(shù)
    formData.append("mailSys", mailSys);

    以上就是vue3使用el-upload上傳文件示例詳解的詳細內(nèi)容,更多關(guān)于vue3 el-upload上傳文件的資料請關(guān)注其它相關(guān)文章!

    標簽: JavaScript
    日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
    夜夜嗨一区二区| 欧产日产国产精品视频| 蜜桃tv一区二区三区| 欧美日韩xxxx| 福利片在线一区二区| 国产精品三级| 久久久一本精品| 老司机久久99久久精品播放免费| 日韩久久电影| 亚洲综合日韩| 国产亚洲精aa在线看| 欧美xxxx中国| 国产专区精品| 久久国产成人| 国产精品videosex极品| а√天堂8资源在线| 影院欧美亚洲| 欧美a级一区二区| 国内精品福利| 日韩午夜高潮| 久久精品一区二区国产| 婷婷丁香综合| 国产欧美三级| 欧美成人基地| 亚洲一本视频| 国产精品久久久久9999高清| 色综合五月天| 亚洲人妖在线| 国产不卡精品在线| 一区视频在线| 麻豆国产精品一区二区三区| 成人av二区| 亚洲精品九九| 欧美日韩在线播放视频| 国产调教一区二区三区| 久久香蕉国产| 国产中文欧美日韩在线| 成人免费网站www网站高清| 中文字幕亚洲在线观看| 天堂√8在线中文| 9久re热视频在线精品| 国产精品欧美三级在线观看| 色婷婷狠狠五月综合天色拍| 国产高清久久| 国产精品蜜芽在线观看| 亚洲精品激情| 午夜精品免费| 欧美日韩精品免费观看视完整| 91久久亚洲| zzzwww在线看片免费| 国产亚洲字幕| 精品捆绑调教一区二区三区| 亚洲激情中文| 国产精品香蕉| 免播放器亚洲一区| 欧美.日韩.国产.一区.二区 | 欧美日韩亚洲一区二区三区在线| 欧美极品一区二区三区| 免费人成黄页网站在线一区二区| 国产精品巨作av| 亚洲在线久久| 日韩高清一区二区| 手机精品视频在线观看| 久久久久欧美精品| 黑森林国产精品av| 综合激情在线| 性欧美xxxx免费岛国不卡电影| 亚洲欧洲另类| 欧美日韩国产传媒| 视频福利一区| 一区二区三区四区日本视频| 黄色成人在线网址| 蜜桃成人av| 欧美日一区二区在线观看| 日韩中文欧美在线| 视频在线在亚洲| 美女精品一区| 影音先锋国产精品| 尤物精品在线| 尤物在线精品| 成人av三级| 国产一区二区三区精品在线观看| 亚洲性视频h| 黄色日韩精品| aⅴ色国产欧美| 国产精品人人爽人人做我的可爱| 麻豆国产91在线播放| 精品中国亚洲| 久久精品理论片| 欧美激情麻豆| 亚洲三区欧美一区国产二区| 蜜桃视频一区二区三区| 91亚洲国产高清| 久久视频一区| 亚洲视频综合| 99在线精品免费视频九九视 | 日韩欧美高清一区二区三区| 日本一区中文字幕| 久久国内精品自在自线400部| 免费不卡中文字幕在线| 欧美91精品| 在线综合欧美| 最新国产精品久久久| 日韩激情一区二区| 亚洲一区二区成人| 日韩在线a电影| 日韩成人av影视| 国产精品一区二区三区www| 日韩一区二区久久| 亚洲精品裸体| 视频在线观看91| 免费在线观看成人| **爰片久久毛片| 国产一区二区三区四区五区| 日韩精品专区| 亚洲精品2区| 亚洲三级在线| 久久精品免视看国产成人| 日韩在线观看一区| 香蕉国产精品| 日韩福利视频导航| 国产精品久久久久久模特| 精品国产一区二区三区av片| 欧美日韩夜夜| 热三久草你在线| 欧美/亚洲一区| 久久亚洲电影| 国产日韩三级| 成人在线黄色| 99成人在线| 国产亚洲精品精品国产亚洲综合 | 久久精品国产亚洲夜色av网站 | 亚洲一区不卡| 免费在线观看一区| 欧美日韩精品一区二区视频| 自拍自偷一区二区三区| 久久字幕精品一区| 91久久黄色| 久久黄色影视| 欧美亚洲激情| 国产乱论精品| 极品日韩av| 欧美日韩1区| 久久影视一区| 国产探花一区在线观看| 久久国产免费| 欧美日本二区| 黄色亚洲在线| 国产成人精品一区二区三区免费 | 最新日韩av| 国产一区二区三区国产精品| sm久久捆绑调教精品一区| 首页欧美精品中文字幕| 成人午夜网址| 九九色在线视频| 欧美伊人影院| 中文亚洲免费| 国产日本亚洲| 欧美freesex黑人又粗又大| 日韩中文字幕1| 国产主播一区| 久久中文在线| 日韩专区精品| 欧美一区二区三区久久| 日韩欧美1区| 无码日韩精品一区二区免费| 国产中文在线播放| 欧美日韩精品一区二区三区视频 | 欧洲一区二区三区精品| 日韩av资源网| 日韩精品诱惑一区?区三区| 日韩精品一级| 国产日韩欧美一区二区三区| 欧美jjzz| 高清一区二区| 日韩av黄色在线| 麻豆精品av| 国产亚洲欧洲| 成人欧美一区二区三区的电影| 久久九九精品| 天堂va在线高清一区| 天堂8中文在线最新版在线| 亚洲一区二区日韩| 欧美日韩中文字幕一区二区三区| 国产精品婷婷| 欧美偷窥清纯综合图区| 女人天堂亚洲aⅴ在线观看| 婷婷精品在线| 亚洲一区二区三区四区五区午夜 | 中文精品电影| 久久国产精品久久久久久电车| 日韩中文字幕亚洲一区二区va在线| 人人精品久久| 免费日韩一区二区三区| 久久国产99| 日韩欧美一区二区三区在线观看| 亚洲综合精品| 老司机精品视频网| 欧美在线综合| 久久中文字幕二区|