亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue導(dǎo)出el-table表格為Excel文件的兩種方式

 更新時(shí)間:2024年09月02日 11:56:20   作者:?jiǎn)茉偈? 
在開發(fā)過(guò)程中,我們經(jīng)常需要將表格數(shù)據(jù)導(dǎo)出為 Excel 文件,大多數(shù)情況下,由后端處理即可,但是當(dāng)數(shù)據(jù)量不大、需要快速響應(yīng)用戶操作、或者數(shù)據(jù)已經(jīng)在前端進(jìn)行處理和展示時(shí),前端該如何實(shí)現(xiàn)呢,本文將介紹兩種方法,需要的朋友可以參考下

前言

在開發(fā)過(guò)程中,我們經(jīng)常需要將表格數(shù)據(jù)導(dǎo)出為 Excel 文件。大多數(shù)情況下,由后端處理即可,但是當(dāng)數(shù)據(jù)量不大、需要快速響應(yīng)用戶操作、或者數(shù)據(jù)已經(jīng)在前端進(jìn)行處理和展示時(shí),前端該如何實(shí)現(xiàn)呢。本文將介紹兩種方法:一種是使用 xlsx.js 進(jìn)行簡(jiǎn)單導(dǎo)出,另一種是使用 xlsx-style-medalsoft 進(jìn)行樣式化導(dǎo)出,包括多 sheet 支持。

方式一:簡(jiǎn)單導(dǎo)出

首先,我們使用 xlsx.js 庫(kù)實(shí)現(xiàn)基本的表格導(dǎo)出功能。這種方法不包含樣式,適用于快速導(dǎo)出數(shù)據(jù)。

import * as XLSX from 'xlsx';

// 創(chuàng)建一個(gè)新的工作簿
const book = XLSX.utils.book_new();

// 將 HTML 表格轉(zhuǎn)換為工作表
const sheet = XLSX.utils.table_to_sheet(this.$refs.exportTableRef.$el);

// 將工作表添加到工作簿
XLSX.utils.book_append_sheet(book, sheet, "Sheet1");

// 導(dǎo)出工作簿為 Excel 文件
XLSX.writeFile(book, "xxx統(tǒng)計(jì).xlsx");

方式二:多 sheet 導(dǎo)出,帶樣式

對(duì)于更復(fù)雜的需求,如導(dǎo)出多個(gè)工作表或添加樣式,我們可以使用 xlsx-style-medalsoft 庫(kù)。

安裝依賴

首先,安裝必要的依賴:

這里注意版本號(hào),有些版本可能會(huì)出現(xiàn)問(wèn)題,我本地目前版本如下

"file-saver": "^2.0.5",
"xlsx": "^0.16.9",
"xlsx-style-medalsoft": "^0.8.13"

封裝導(dǎo)出功能

接下來(lái),我們封裝一個(gè)函數(shù),用于導(dǎo)出帶樣式的 Excel 文件:

import FileSaver from 'file-saver';
import * as XLSX from 'xlsx';
import XLSXStyle from 'xlsx-style-medalsoft';

const OMS = {};

// 導(dǎo)出 Excel 文件,支持多 sheet 和樣式
OMS.downLoadXlsx = ({ sheets = [], name = '文件' }) => {
  const workbook = XLSX.utils.book_new();

  sheets.forEach(sheetData => {
    const { dom, sheetName, columnWidth = [], raw } = sheetData;
    const table = dom;

    // 移除固定列,避免重復(fù)內(nèi)容
    ['el-table__fixed', 'el-table__fixed-right'].forEach(className => {
      const fixedTable = table.querySelector(`.${className}`);
      if (fixedTable) table.removeChild(fixedTable);
    });

    // 轉(zhuǎn)換表格為工作表
    const sheet = XLSX.utils.table_to_sheet(table, { raw });

    // 刪除空行
    Object.keys(sheet).forEach(key => {
      if (!key.startsWith('!') && sheet[key].v === '') delete sheet[key];
    });

    // 設(shè)置列寬度
    if (columnWidth.length > 0) {
      columnWidth.forEach((width, index) => {
        sheet['!cols'][index] = { wch: width };
      });
    } else {
      // 默認(rèn)列寬
      for (let i = 0; i < 30; i++) {
        sheet['!cols'][i] = { wch: 12.5 };
      }
    }

    // 應(yīng)用樣式
    Object.keys(sheet).forEach(key => {
      if (!key.startsWith('!')) {
        sheet[key].s = {
          font: { sz: 11, bold: false, name: '宋體', color: { rgb: '000000' } },
          alignment: { horizontal: 'center', vertical: 'center', wrapText: false },
          border: {}
        };
      }
    });

    // 合并單元格
    const range = sheet['!merges'];
    if (range) {
      range.forEach(item => {
        const startCol = item.s.c, endCol = item.e.c;
        const startRow = item.s.r, endRow = item.e.r;
        const firstCell = sheet[XLSX.utils.encode_cell({ r: startRow, c: startCol })];
        for (let row = startRow; row <= endRow; row++) {
          for (let col = startCol; col <= endCol; col++) {
            sheet[XLSX.utils.encode_cell({ r: row, c: col })] = firstCell;
          }
        }
      });
    }

    // 添加工作表到工作簿
    XLSX.utils.book_append_sheet(workbook, sheet, sheetName);
  });

  // 導(dǎo)出工作簿
  const excelData = XLSXStyle.write(workbook, { bookType: 'xlsx', type: 'buffer' });
  FileSaver.saveAs(new Blob([excelData], { type: 'application/octet-stream' }), `${name}.xlsx`);
};

export default OMS;

使用方法

最后,我們?cè)谛枰褂玫牡胤揭耄?/p>

import OMS from "@/utils/exportToExcel";

OMS.downLoadXlsx({
  sheets: [
    {
      dom: this.$refs.rowTableRef.$el,
      sheetName: this.rowData[0].hospName,
      columnWidth: [20, 15, 15, 15, 15, 15, 15, 15] // 可選,設(shè)置列寬度
    },
    {
      dom: this.$refs.table.$el,
      sheetName: "明細(xì)",
      raw: true,
      columnWidth: [10, 15, 12, 15, 15, 15, 15, 15] // 可選,設(shè)置列寬度
    }
    // 可添加更多工作表
  ],
  name: "報(bào)告"
});

通過(guò)這種方式,我們就實(shí)現(xiàn)了前端導(dǎo)出帶樣式的 Excel 文件,滿足多 sheet,帶樣式的業(yè)務(wù)需求。

但是需要注意的是如果數(shù)據(jù)量不大、需要快速響應(yīng)用戶操作、或者數(shù)據(jù)已經(jīng)在前端進(jìn)行處理和展示,前端來(lái)做導(dǎo)出是可以的。而如果數(shù)據(jù)量很大、需要復(fù)雜的數(shù)據(jù)處理、或者需要保證數(shù)據(jù)的安全性和一致性,后端導(dǎo)出可能更合適。

以上就是Vue導(dǎo)出el-table表格為Excel文件的兩種方式的詳細(xì)內(nèi)容,更多關(guān)于Vue導(dǎo)出el-table為Excel的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue項(xiàng)目中安裝依賴npm?install一直報(bào)錯(cuò)的解決過(guò)程

    Vue項(xiàng)目中安裝依賴npm?install一直報(bào)錯(cuò)的解決過(guò)程

    這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目中安裝依賴npm?install一直報(bào)錯(cuò)的解決過(guò)程,要解決NPM安裝依賴報(bào)錯(cuò),首先要分析出錯(cuò)誤的原因,文中將解決的過(guò)程介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • Vue element-ui父組件控制子組件的表單校驗(yàn)操作

    Vue element-ui父組件控制子組件的表單校驗(yàn)操作

    這篇文章主要介紹了Vue element-ui父組件控制子組件的表單校驗(yàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • vue+springboot+element+vue-resource實(shí)現(xiàn)文件上傳教程

    vue+springboot+element+vue-resource實(shí)現(xiàn)文件上傳教程

    這篇文章主要介紹了vue+springboot+element+vue-resource實(shí)現(xiàn)文件上傳教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • 你不可不知的Vue.js列表渲染詳解

    你不可不知的Vue.js列表渲染詳解

    這篇文章主要給大家介紹了關(guān)于你不可不知的Vue.js列表渲染的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vue.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue組件中的樣式屬性scoped實(shí)例詳解

    vue組件中的樣式屬性scoped實(shí)例詳解

    vue組件中的style標(biāo)簽標(biāo)有scoped屬性時(shí)表明style里的css樣式只適用于當(dāng)前組件元素 。接下來(lái)通過(guò)本文給大家分享vue組件中的樣式屬性scoped實(shí)例詳解,感興趣的朋友跟隨小編一起看看吧
    2018-10-10
  • vue項(xiàng)目引入本地bootstrap不生效問(wèn)題及解決

    vue項(xiàng)目引入本地bootstrap不生效問(wèn)題及解決

    這篇文章主要介紹了vue項(xiàng)目引入本地bootstrap不生效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue.js中methods watch和computed的區(qū)別示例詳解

    vue.js中methods watch和computed的區(qū)別示例詳解

    methods,watch和computed都是以函數(shù)為基礎(chǔ)的,但各自卻都不同,這篇文章主要給大家介紹了關(guān)于vue.js中methods watch和computed區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式

    vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式

    這篇文章主要介紹了vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue3中setup方法的用法詳解

    Vue3中setup方法的用法詳解

    在vue3版本中,引入了一個(gè)新的函數(shù),叫做setup。這篇文章將為大家詳細(xì)介紹一下Vue3中setup方法的用法,感興趣小伙伴的可以了解一下
    2022-07-07
  • Vue中使用v-model雙向數(shù)據(jù)綁定select、checked等多種表單元素的方法

    Vue中使用v-model雙向數(shù)據(jù)綁定select、checked等多種表單元素的方法

    ?v-model?指令可以用在表單?input、textarea?及?select?元素上創(chuàng)建雙向數(shù)據(jù)綁定,它會(huì)根據(jù)控件類型自動(dòng)選取正確的方法來(lái)更新元素,本文給大家介紹Vue中如何使用v-model雙向數(shù)據(jù)綁定select、checked等多種表單元素,感興趣的朋友一起看看吧
    2023-10-10

最新評(píng)論