电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

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

    el-upload上傳文件

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

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

    屬性

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

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

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

    方法

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

    上傳圖片的實現

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

    <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({
      // 允許上傳文件件的最大數量
      limit:{
        type:Number
      },
      // 是否禁用上傳
      disabled:{
        type:Boolean,
        default:false
      },
      // 文件列表類型
      listType:{
        type:String,
        default:"picture-card"
      },
      // 上傳時攜帶的額外參數
      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({});
    // 預覽大圖
    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);
    };
    // 文件上傳數量限制
    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("資產添加成功");
      }).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以內的圖片文件!");
        return false
      }
      return true;
    };
    // 文件上傳成功時的鉤子
    const uploadSuccess = (response, file, fileList) => {
      // 上傳成功之后后臺返回的數據
      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;我們的需求中還需要設置文件的隨機數,因此請求頭需要是這樣的Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

    下面是我遇到的問題。

    問題1

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

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

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

    問題2

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

    但是我不設置的話就是默認的application/json。

    于是查閱資料發現axios的transformRequest屬性可以在向服務器發送請求數據之前修改請求數據,因為我們的請求在默認的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("資產添加成功");
      }).catch((err) => {
        console.log(err);
      });
    

    問題3

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

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

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

    標簽: JavaScript
    主站蜘蛛池模板: 粘度计NDJ-5S,粘度计NDJ-8S,越平水分测定仪-上海右一仪器有限公司 | 重庆波纹管|重庆钢带管|重庆塑钢管|重庆联进管道有限公司 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 隔爆型防爆端子分线箱_防爆空气开关箱|依客思 | 流变仪-热分析联用仪-热膨胀仪厂家-耐驰科学仪器商贸 | IIS7站长之家-站长工具-爱网站请使用IIS7站长综合查询工具,中国站长【WWW.IIS7.COM】 | 南京展台搭建-南京展会设计-南京展览设计公司-南京展厅展示设计-南京汇雅展览工程有限公司 | 金刚网,金刚网窗纱,不锈钢网,金刚网厂家- 河北萨邦丝网制品有限公司 | 网站建设-网站制作-网站设计-网站开发定制公司-网站SEO优化推广-咏熠软件 | 低噪声电流前置放大器-SR570电流前置放大器-深圳市嘉士达精密仪器有限公司 | 北京网站建设-企业网站建设-建站公司-做网站-北京良言多米网络公司 | 宜兴紫砂壶知识分享 - 宜兴壶人| 成都APP开发-成都App定制-成都app开发公司-【未来久】 | 广州云仓代发-昊哥云仓专业电商仓储托管外包代发货服务 | 浙江皓格药业有限公司| 昆明网络公司|云南网络公司|昆明网站建设公司|昆明网页设计|云南网站制作|新媒体运营公司|APP开发|小程序研发|尽在昆明奥远科技有限公司 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 客服外包专业服务商_客服外包中心_网萌科技 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 广州网站建设_小程序开发_番禺网站建设_佛山网站建设_粤联网络 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 | 过跨车_过跨电瓶车_过跨转运车_横移电动平车_厂区转运车_无轨转运车 | 美国HASKEL增压泵-伊莱科elettrotec流量开关-上海方未机械设备有限公司 | 翅片管散热器价格_钢制暖气片报价_钢制板式散热器厂家「河北冀春暖气片有限公司」 | 吉林污水处理公司,长春工业污水处理设备,净水设备-长春易洁环保科技有限公司 | 青海电动密集架_智能密集架_密集架价格-盛隆柜业青海档案密集架厂家 | 大连海岛旅游网>>大连旅游,大连海岛游,旅游景点攻略,海岛旅游官网 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 网站seo优化_seo云优化_搜索引擎seo_启新网络服务中心 | 上海乾拓贸易有限公司-日本SMC电磁阀_德国FESTO电磁阀_德国FESTO气缸 | 石牌坊价格石牌坊雕刻制作_石雕牌坊牌楼石栏杆厂家_山东嘉祥石雕有限公司 | 魔方网-培训咨询服务平台| 洗石机-移动滚筒式,振动,螺旋,洗矿机-青州冠诚重工机械有限公司 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 广州昊至泉水上乐园设备有限公司| 水厂自动化-水厂控制系统-泵站自动化|控制系统-闸门自动化控制-济南华通中控科技有限公司 | PTFE接头|聚四氟乙烯螺丝|阀门|薄膜|消解罐|聚四氟乙烯球-嘉兴市方圆氟塑制品有限公司 | 济南铝方通-济南铝方通价格-济南方通厂家-山东鲁方通建材有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | 雷冲击高压发生器-水内冷直流高压发生器-串联谐振分压器-武汉特高压电力科技有限公司 | 高铝砖-高铝耐火球-高铝耐火砖生产厂家-价格【荣盛耐材】 |