element中文件上傳

来源:https://www.cnblogs.com/qdclub/archive/2019/03/17/10547611.html
-Advertisement-
Play Games

vue+element 文件操作 作者:一粒塵土 時間:2019 3 17 註:以下操作針對 vue cli 目錄 "使用" "組件常用參數" "組件常用方法" "上傳文件" "上傳文件格式限制" "回顯文件" "下載文件" "刪除文件" 使用 使用npm安裝Element ui 依賴 配置vue中 ...


vue+element 文件操作

作者:一粒塵土  時間:2019-3-17  註:以下操作針對 vue-cli

目錄

使用

  • 使用npm安裝Element-ui 依賴
    $ npm i element-ui -S
  • 配置vue中的 main.js 文件中添加如下代碼
    import ElementUI from 'element-ui' // 引入element import 'element-ui/lib/theme-chalk/index.css' // 引入css樣式 Vue.use(ElementUI) // 中間件全局註冊

組件常用參數

參數 說明 類型 可選值 預設值
action 必選參數,上傳的地址 string - -
multiple 是否支持多選文件 boolean - -
data 上傳時附帶的額外參數 object - -
accept 接受上傳的文件類型 string - -
on-preview 點擊文件列表中已上傳的文件時的鉤子 function(file) - -
on-remove 文件列表移除文件時的鉤子 function(file, fileList) - -
on-success 文件上傳成功時的鉤子 function(response, file, fileList) - -
on-error 文件上傳失敗時的鉤子 function(err, file, fileList) - -
on-progress 文件上傳時的鉤子 function(event, file, fileList) - -
on-change 文件狀態改變時的鉤子,添加文件、上傳成功和上傳失敗時都會被調用 function(file, fileList) - -
before-upload 上傳文件之前的鉤子,參數為上傳的文件,若返回 false 或者返回 Promise 且被 reject,則停止上傳 function(file) - -
before-remove 刪除文件之前的鉤子,參數為上傳的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,則停止上傳 function(file, fileList) - -
auto-upload 是否在選取文件後立即進行上傳 boolean - true
file-list 上傳的文件列表, 例如: [{name: 'food.jpg', url: 'https://xxx.cdn.com/xxx.jpg'}] array - []
limit 最大允許上傳個數 number - -

組件常用方法

參數 說明 參數
clearFiles 清空已上傳的文件列表(該方法不支持在 before-upload 中調用) -

文件上傳

在進行文件上傳時,因為需要的不同,所以可分為 即時上傳延時上傳 兩種情況

即時上傳:選中文件之後立即上傳

說明:文件上傳時action屬性為文件上傳的地地址,如果上傳文件時需要攜帶參數,可放在data屬性中(對象格式)

<el-upload
  class="upload-demo"
  ref="upload"
  action="/jgxf/System/fileUpload.mvc" // 上傳文件的地址
  :on-change="getFiles" // 文件改變時調用的鉤子函數
  multiple // 是否支持上傳多條文件
  :data="addFilesDate" // 上傳文件時攜帶的參數
  :file-list="fileList"> // 上文文件的列表
  <el-button size="small" type="primary">選擇文件</el-button>
</el-upload>

延時上傳:可用於表單操作時傳遞文件,在表單信息保存完畢後上傳文件操作

說明:延時上傳需要依靠auto-upload屬性來設置文件是否即時上傳,預設值為 true,如果設置為false時,選擇文件之後不會上傳文件,我們可在需要上傳文件時調用如下方法即可上傳文件

$ this.$refs.upload.submit() // 上傳文件操作
<el-upload
  class="upload-demo"
  ref="upload"
  action="/jgxf/System/fileUpload.mvc"
  :on-change="getFiles"
  multiple
  :data="addFilesDate"
  :file-list="fileList"
  :auto-upload="false"">
  <el-button size="small" type="primary">選擇文件</el-button>
</el-upload>

上傳文件格式限制

在上傳文件附件的時候,因為需求不同,所以對於文件格式的限制也有所不同,在這裡可以使用accept(接收文件類型),但是僅僅使用該屬性並不能完全限制用戶的選擇,此時我們可以結合 before-upload函數來進行限制,如此即可真正的限制文件上傳時的格式限制

<el-upload
  class="upload-demo"
  ref="upload"
  action="/jgxf/System/fileUpload.mvc"
  :on-change="getFiles"
  :before-upload="beforeUpload" // 文件上傳前的回調
  multiple
  :accept=".doc, .docx, .xls, .xlsx" // 接收的文件類型
  :data="addFilesDate"
  :file-list="fileList">
  <el-button size="small" type="primary">選擇文件</el-button>

添加:我在這裡寫了個方法,可以在before-upload函數中調用 this.fileUploadSuffix(fileList, suffix),來判斷用戶選擇的問價是否是符合尾碼的,代碼如下

/**
 * 文件上傳 限制格式
 * @param fileList 文件列表( 數組)
 * @param suffix 文件格式限制(字元串)".doc, .docx, .wps"
 * @param blooean 返回值
 */
Vue.prototype.fileUploadSuffix = function (fileList, suffix) {
  let blooean = null
  for (let i in fileList) {
    let item = fileList[i] // 某一條文件信息
    let fileName = item.name.lastIndexOf('.') // 取到文件名開始到最後一個點的長度
    let fileNameLength = item.name.length // 取到文件名長度
    let hz = item.name.substring(fileName + 1, fileNameLength) // 獲取上傳文件的尾碼名
    // 判斷文件名尾碼是否合法
    if (suffix.indexOf(hz) === -1) { // 不合法上傳文件
      // 刪除上傳的文件列表中的不合法文件類型
      fileList.splice(i--, 1) // 刪除列表中的數據(刪除後文件調整)
      // 彈窗顯示判斷
      blooean = true
    }
  }
  return blooean // 返回參數
}

回顯文件

根據element文檔可知,儲存文件上傳的屬性為 fileList ,我們只需將接受的參數,按照fileList的name屬性附上值,即可回顯我們需要的格式,當然我們也可以添加替他屬性,用來進行下載刪除等操作

屬性值 參數
name 文件名稱
url 文件上傳的路徑

下載文件

在element的 upload 組件中有一個屬性可讓我們用來進行文件的下載 on-preview(點擊文件列表中已上傳的文件時的鉤子),然後在該函數中調用window.open(url) 方法 url 下載文件的地址

刪除文件

在頁面回顯之後,也會有刪除文件的操作,此時我們可以使用該組件中的 on-remove(文件列表移除文件的操作)屬性 ,再調用該參數的時候文件列表中的數據將會被刪除,這種效果並不是很好,由此我們可以使用 before-remove 來進行刪除文件的操作,如果用戶選擇確定刪除時,我們再去調用刪除文件的介面,在刪除成功之後,我們在進行頁面上列表的屋裡刪除,就好了

<!--html代碼-->
<el-upload
  :befor-remove="beforRemove"
  ></el-upload>

<!--js代碼-->
beforeRemove (file, fileList) {
  this.$alert(`確定移除該文件?`, '提示', {
    confirmButtonText: '確定',
    cancelButtonText: '取消',
    type: 'warning'
  }).then(() => {
    this.deleteFile(file, fileList)
  }).catch(() => {
    this.$message({
      type: 'info',
      message: '取消刪除操作'
    })
  })
  return false
},
deleteFile (file, fileList) {
  let file = file
  let fileList = fileList // 接收文件
  this.post(() => {
    url: '', // 刪除文件的介面
    data: {} // 傳遞的參數
  }, (res) => {
    // 刪除成功,更新頁面中的文件列表信息
  })
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 早期由於瀏覽器廠商對於瀏覽器市場的爭奪,各家瀏覽器廠商對同一功能的JavaScript的實現都不進相同,本節內容介紹JavaScript的DOM事件模型及事件處理程式的分類。 1、DOM事件模型。DOM事件模型分為兩種:事件冒泡和事件捕獲。事件冒泡最初是微軟提出的DOM事件流的模型,顧名思義,就是值 ...
  • 層疊樣式表(英文全稱:Cascading Style Sheets)是一種用來表現HTML(標準通用標記語言的一個應用)或XML(標準通用標記語言的一個子集)等文件樣式的電腦語言。CSS不僅可以靜態地修飾網頁,還可以配合各種腳本語言動態地對網頁各元素進行格式化。 基本語法 在head標簽裡面,寫入 ...
  • 最近我在瀏覽別的博客的文章時,無意間發現了一個很好看的小裝飾。那就是在WordPress菜單欄上的小圖標。於是我研究了研究,弄到了設置方法之後決定把它分享出來。 菜單欄的小圖標 設置步驟: 1, 我們先到WordPress後臺--插件--安裝插件頁面 搜索:Font Awesome 4 Menus, ...
  • mysql數據讀庫的\r\n換行符處理 這個問題是我在採集數據時發現的,採集網頁的數據,大概有6千多條,採集的內容保留了最原始的\r\n和\n換行字元,但在mysql管理工具中(phpmyadmin和Navicat)查看時,欄位內容有換行,不顯示\r\n和\n。 在html中展現的時候,卻不像mys ...
  • boostrap中模態框顯示在陰影之下 出現這種情況的原因我開始也搞了很久,問題出現在哪裡呢? 有事問百度,在百度上查了一下資料,他們主要的解決辦法:是 修改標簽的z-index屬性的值, 我試著改了z-index的值(z-index屬性要在設置了定位時才能用), 但是沒有解決這個問題, 後來又仔細 ...
  • 本篇文章是接著Spring Boot 入門(五):集成 AOP 進行日誌管理寫的,主要集成了樹形圖,在部門列表或者許可權列表中,樹形圖經常被用上。主要是根據相應的 API 憑藉 html 字元串 1.treetable 1 <link href="/plugins/treeTable/themes/d ...
  • 本文旨在介紹移動端h5分頁查詢實現 1.前端html 前端基於weui 樣式庫實現 參考http://jqweui.com/ 1 <div class="weui-search-bar" id="searchBar"> 2 <form class="weui-search-bar__form"> 3 ...
  • 父組件向子組件傳值 1. 組件實例定義方式,註意:一定要使用 屬性來定義父組件傳遞過來的數據 2. 使用 或簡化指令,將數據傳遞到子組件中: 子組件向父組件傳值 1. 原理:父組件將方法的引用,傳遞到子組件內部,子組件在內部調用父組件傳遞過來的方法,同時把要發送給父組件的數據,在調用方法的時候當作參 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...