欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue前端表格導(dǎo)出Excel文件的圖文教程

 更新時間:2023年04月24日 12:01:15   作者:Amazing_time  
我們在開發(fā)的時候會經(jīng)常用的導(dǎo)出excel表格功能,剛好自己開發(fā)有遇到,就記錄一下,下面這篇文章主要給大家介紹了關(guān)于Vue前端表格導(dǎo)出Excel文件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

分享一個Vue前端導(dǎo)出Excel文件的方法。記錄學(xué)習(xí)!

功能需求:將表格的全部數(shù)據(jù)導(dǎo)出Excel格式的文件
前端:Vue3+Element-Plus

這個導(dǎo)出方法全部為前端操作,后端只需要傳入表格數(shù)據(jù)到前端即可(基礎(chǔ)的多表查詢,用的內(nèi)連接)

一、實(shí)現(xiàn)

1. 頁面

2.代碼

2.1 核心方法

/**
 * 表格數(shù)據(jù)導(dǎo)出Excel實(shí)際方法
 * @param list
 */
const exportList = (list) => {
  //表格表頭,導(dǎo)出表頭
  let tableHeader = [['#', '資產(chǎn)編號', '資產(chǎn)名稱', '資產(chǎn)類別', '資產(chǎn)型號', "資產(chǎn)單價", "資產(chǎn)金額",
    "生產(chǎn)廠家", "生產(chǎn)日期", "購買日期", "購買人", "狀態(tài)", "庫存數(shù)量"]]
  list.forEach((item, index) => {
    let rowData = []
    //導(dǎo)出內(nèi)容的字段
    rowData = [
      index + 1,
      item.zcbh,
      item.zcmc,
      item.name,
      item.zcxh,
      item.zcdj,
      item.zcje,
      item.sccj,
      currencyFormatDate(item.scrq),
      currencyFormatDate(item.gmrq),
      item.gmr,
      item.sts,
      item.kcsl,
    ]
    tableHeader.push(rowData)
  })
  let wb = XLSX.utils.book_new()
  let ws = XLSX.utils.aoa_to_sheet(tableHeader)
  XLSX.utils.book_append_sheet(wb, ws, '資產(chǎn)設(shè)備基本信息') // 工作簿名稱
  XLSX.writeFile(wb, '資產(chǎn)設(shè)備基本信息.xlsx') // 保存的文件名
}

將這個導(dǎo)出方法單獨(dú)封裝出來,帶一個參數(shù),即需要導(dǎo)出的所有數(shù)據(jù)的List集合,那么在調(diào)用的時候傳參即可使用。

  1. tableHeader 定義表格的表頭(此處并不是很嚴(yán)謹(jǐn),因?yàn)檫€包含了表格的數(shù)據(jù),暫時為空,后面遍歷時傳入)。
  2. rowData 是表格具體數(shù)據(jù)內(nèi)容的數(shù)組,遍歷時傳入。
  3. tableHeader.push(rowData) 將內(nèi)容放入tableHeader中,形成完整的表格數(shù)據(jù)。
  4. let wb = XLSX.utils.book_new() 定義表格實(shí)例。
  5. let ws = XLSX.utils.aoa_to_sheet(tableHeader) 創(chuàng)建工作簿,將表格內(nèi)容放入工作簿。

2.2 調(diào)用方法

/**
 * 表格數(shù)據(jù)導(dǎo)出Excel調(diào)用方法
 */
const exportExcel = () => {
  ElMessageBox.confirm(
          '確定導(dǎo)出資產(chǎn)設(shè)備基本信息表嗎?',
          '提示',
          {
            confirmButtonText: '確定',
            cancelButtonText: '取消',
            type: 'warning',
          }
  )
          .then(async () => {
            let list = [];
            const res = await request.get("asset/listAll");
            console.log(res)
            list = res.data.assetsAllList
            exportList(list);
            if (res.data.code === 200) {
              ElMessage({
                type: 'success',
                message: '即刻開始下載',
              })
            }
          })
          .catch(() => {
          })
}

await request.get(“asset/listAll”) 請求后端接口,拿到結(jié)果。將結(jié)果中的集合賦值給提前定義好的list數(shù)組list = res.data.assetsAllList。用了MessageBox消息彈框,根據(jù)自己的實(shí)際需求哈用到了異步等待,上面的request.get是自己封裝的axios方法 3.演示

結(jié)束

到此這篇關(guān)于Vue前端表格導(dǎo)出Excel文件的文章就介紹到這了,更多相關(guān)Vue前端表格導(dǎo)出Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue3源碼剖析之簡單實(shí)現(xiàn)方法

    vue3源碼剖析之簡單實(shí)現(xiàn)方法

    源碼的重要性相信不用再多說什么了吧,特別是用Vue 框架的,一般在面試的時候面試官多多少少都會考察源碼層面的內(nèi)容,下面這篇文章主要給大家介紹了關(guān)于vue3源碼剖析之簡單實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • 使用vue-router切換組件時使組件不銷毀問題

    使用vue-router切換組件時使組件不銷毀問題

    這篇文章主要介紹了使用vue-router切換組件時使組件不銷毀問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue之el-option下拉框綁定問題

    Vue之el-option下拉框綁定問題

    這篇文章主要介紹了Vue之el-option下拉框綁定問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue項(xiàng)目依賴包安裝及配置過程

    Vue項(xiàng)目依賴包安裝及配置過程

    這篇文章主要介紹了Vue項(xiàng)目依賴包安裝及配置過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-12-12
  • Vue使用driver.js做引導(dǎo)頁

    Vue使用driver.js做引導(dǎo)頁

    Driver.js是一個功能強(qiáng)大且高度可定制的基于原生JavaScript開發(fā)的新用戶引導(dǎo)庫,本文主要介紹了Vue使用driver.js做引導(dǎo)頁,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • vue指令中的v-once用法

    vue指令中的v-once用法

    這篇文章主要介紹了vue指令中的v-once用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue3.x中emits的基本用法實(shí)例

    vue3.x中emits的基本用法實(shí)例

    emits是Vue3新增的選項(xiàng),emits主要作用在子組件中,用于接收在父組件中綁定的方法,這篇文章主要給大家介紹了關(guān)于vue3.x中emits的基本用法,需要的朋友可以參考下
    2022-07-07
  • vue中el-dialog打開與關(guān)閉的幾種方式

    vue中el-dialog打開與關(guān)閉的幾種方式

    本文主要介紹了vue中el-dialog打開與關(guān)閉的幾種方式,包括 update:visible, ref和兄弟 bus這三種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • 封裝Vue Element的table表格組件的示例詳解

    封裝Vue Element的table表格組件的示例詳解

    這篇文章主要介紹了封裝Vue Element的table表格組件的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-08-08
  • vue中引入mousewheel事件及兼容性處理方式

    vue中引入mousewheel事件及兼容性處理方式

    這篇文章主要介紹了vue中引入mousewheel事件及兼容性處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評論