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

React.js前端導(dǎo)出Excel的方式

 更新時間:2022年07月08日 14:32:15   作者:狂奔滴小馬  
這篇文章主要為大家介紹了React.js前端導(dǎo)出Excel的方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

前段時間,項目上有個需求需要將數(shù)據(jù)報表導(dǎo)出為 excel 的需求,這本來是后端的工作,前端只需要一個 a 標(biāo)簽,就可以下載文件,但不巧的是,正好遇到后端請假,而且項目比較著急,那么前端是否可以實現(xiàn)呢?

實現(xiàn)方式

經(jīng)過一頓搜索后,發(fā)現(xiàn)有這么幾個 npm 庫

  • react-csv
  • 根據(jù)給定的數(shù)據(jù)生成 CSV 文件,數(shù)據(jù)可以是二維數(shù)組、對象數(shù)組或字符串。
  • xlsx 進(jìn)入 xlsx 官網(wǎng),官網(wǎng)稱為 SheetJS,它支持瀏覽器、nodejs、deno、和 react-native,瀏覽器兼容 ie10+。 SheetJS 社區(qū)版提供經(jīng)過實戰(zhàn)考驗的開源解決方案,用于從幾乎所有復(fù)雜的電子表格中提取有用的數(shù)據(jù),并生成新的電子表格,這些新的電子表格可以與傳統(tǒng)軟件和現(xiàn)代軟件一起使用。

csv 與 Excel 的區(qū)別

從名字上看一個是導(dǎo)出 csv,一個是導(dǎo)出 excel,那么這 2 者有什么區(qū)別呢?

Excel 是一個電子表格,將文件保存為自己的專有格式,即 xls 或 xlsx,它保存有關(guān)工作簿中所有工作表的信息

CSV 代表 Comma Separated Values ,這是一個純文本格式,用逗號分隔一系列值,但不包含格式,公式,宏等,擴(kuò)展名為.csv 的分隔文本文件的格式

總結(jié)來說,Excel 不僅可以存儲數(shù)據(jù),還可以對數(shù)據(jù)進(jìn)行操作,CSV 文件只是一個文本文件,它存儲數(shù)據(jù),它也被稱為平面文件,任何用于解析 Excel 數(shù)據(jù)的編程語言庫通常都會更大,更慢,更復(fù)雜,任何編程語言來解析 CSV 數(shù)據(jù)是微不足道的,生成它是非常容易的。

react-csv

實現(xiàn)代碼

import React from 'react';
import { CSVLink } from 'react-csv';
const headers = [
  { label: 'First Name', key: 'firstname' },
  { label: 'Last Name', key: 'lastname' },
  { label: 'Email', key: 'email' },
];
const data = [
  { firstname: 'Ahmed', lastname: 'Tomi', email: 'ah@smthing.co.com' },
  { firstname: 'Raed', lastname: 'Labes', email: 'rl@smthing.co.com' },
  { firstname: 'Yezzi', lastname: 'Min l3b', email: 'ymin@cocococo.com' },
];
export default function App() {
  return (
    <CSVLink data={data} headers={headers}>
      Download me
    </CSVLink>
  );
}

react-csv 使用非常簡單,只需要 npm 安裝后就可以使用,使用 headers 字段可以指定表頭。

xlsx

xlsx 官網(wǎng)有數(shù)據(jù)導(dǎo)入、數(shù)據(jù)導(dǎo)出、數(shù)據(jù)處理等功能,非常強(qiáng)大,這里我們只處理數(shù)據(jù)到功能。

cdn 方式

  • 首先確保頁面上有一個表格,并且有一個唯一 ID:
<table id="TableToExport">
  • 在頁面上引入 SheetJS
<script src="https://cdn.sheetjs.com/xlsx-latest/package/dist/xlsx.full.min.js"></script>
  • 添加一個按鈕用于導(dǎo)出 Excel
<button id="sheetjsexport"><b>導(dǎo)出 XLSX</b></button>
  • 綁定點(diǎn)擊事件:
document.getElementById("sheetjsexport").addEventListener('click', function() {
  /*根據(jù)頁面上的表格創(chuàng)建工作表 */
  var wb = XLSX.utils.table_to_book(document.getElementById("TableToExport"));
  /* 導(dǎo)出文件下載 */
  XLSX.writeFile(wb, "SheetJSTable.xlsx");
});

在 react 中使用

function Table2XLSX(props) {
  const xport = async () => {
      const table = document.getElementById("Table2XLSX");
      const wb = XLSX.utils.table_to_book(table);
      XLSX.writeFile(wb, "SheetJSTable.xlsx");
  };
  return (<>
    <table id="Table2XLSX"><tbody>
      <tr><td colSpan="3">SheetJS Table Export</td></tr>
      <tr><td>Author</td><td>ID</td><td>Note</td></tr>
      <tr><td>SheetJS</td><td>7262</td><td>Hi!</td></tr>
      <tr><td colSpan="3">
        <a  rel="external nofollow" >Powered by SheetJS</a>
      </td></tr>
    </tbody></table>
    <button onClick={xport}><b>Export XLSX!</b></button>
  </>);
}

以上方法是將頁面上的表格轉(zhuǎn)為 excel,那么能否跟 react-csv 一樣json 轉(zhuǎn) excel 呢?

json 轉(zhuǎn) excel

/**
 * 導(dǎo)出 excel 文件
 * @param array JSON 數(shù)組
 * @param sheetName 第一張表名
 * @param fileName 文件名
 */
export function exportExcelFile(array=[], sheetName = 'sheet表', fileName = 'example.xlsx') {
  const jsonWorkSheet = xlsx.utils.json_to_sheet(array);
  const workBook = {
    SheetNames: [sheetName],
    Sheets: {
      [sheetName]: jsonWorkSheet,
    }
  };
  return xlsx.writeFile(workBook, fileName);
}

xlsx.utils.json_to_sheet 可以將 JSON 數(shù)據(jù)存儲到 sheet 中,然后使用 xlsx.writeFile 寫入文件并且下載。

<button
  disabled={dataSource.length === 0}
  onClick={() => exportExcelFile(dataSource)}
>
  導(dǎo)出 Excel
</button>

結(jié)語

如果你有多個 Sheet 要導(dǎo)出成一個 excel,就只能使用 xlsx,其實對于我們的項目需求,只有個表要導(dǎo)出使用 xlsx 和 csv 都可以,如果導(dǎo)出的數(shù)據(jù)需要給其他程序處理,建議使用 csv 格式,數(shù)據(jù)會比較好處理。

以上就是React.js前端導(dǎo)出Excel的方式的詳細(xì)內(nèi)容,更多關(guān)于React.js前端導(dǎo)出Excel的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • react后臺系統(tǒng)最佳實踐示例詳解

    react后臺系統(tǒng)最佳實踐示例詳解

    這篇文章主要為大家介紹了react后臺系統(tǒng)最佳實踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • React使用有限狀態(tài)機(jī)的實現(xiàn)示例

    React使用有限狀態(tài)機(jī)的實現(xiàn)示例

    本文主要介紹了React使用有限狀態(tài)機(jī)的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • react router 4.0以上的路由應(yīng)用詳解

    react router 4.0以上的路由應(yīng)用詳解

    本篇文章主要介紹了react router 4.0以上的路由應(yīng)用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 前端面試題必會之前端react面試題

    前端面試題必會之前端react面試題

    在前端面試過程中經(jīng)常會問到一些面試題,今天小編抽空給大家講解前端面試題之必會react面試題,需要的朋友可以參考下
    2023-03-03
  • 淺談react 同構(gòu)之樣式直出

    淺談react 同構(gòu)之樣式直出

    這篇文章主要介紹了淺談react 同構(gòu)之樣式直出,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • create-react-app 修改為多入口編譯的方法

    create-react-app 修改為多入口編譯的方法

    這篇文章主要介紹了create-react-app 修改為多入口編譯的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • TypeScript在React中的應(yīng)用技術(shù)實例解析

    TypeScript在React中的應(yīng)用技術(shù)實例解析

    這篇文章主要為大家介紹了TypeScript在React中的應(yīng)用技術(shù)實例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • D3.js(v3)+react 實現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本)

    D3.js(v3)+react 實現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本)

    散點(diǎn)圖(Scatter Chart),通常是一橫一豎兩個坐標(biāo)軸,數(shù)據(jù)是一組二維坐標(biāo),分別對應(yīng)兩個坐標(biāo)軸,與坐標(biāo)軸對應(yīng)的地方打上點(diǎn)。由此可以猜到,需要的元素包括circle(圓)和axis(坐標(biāo)軸),接下來通過本文大家分享D3.js(v3)+react 實現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本) ,一起看看
    2019-05-05
  • React實現(xiàn)簡單登錄的項目實踐

    React實現(xiàn)簡單登錄的項目實踐

    登錄、注冊、找回密碼是前端項目經(jīng)常遇到的需求,本文主要介紹了React實現(xiàn)簡單登錄的項目實踐,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • Modal.confirm是否違反了React模式分析

    Modal.confirm是否違反了React模式分析

    這篇文章主要為大家介紹了Modal.confirm是否違反了React模式分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評論