vue预览xlsx

预览文件的数据流从服务器的接口传入:

  1. 安装插件 yarn add xlsx

2.引入插件

import XLSX from "xlsx" // 早期版本的引入方式

import * as XLSX from 'xlsx/xlsx.mjs' // 为了适应新版本xlsx的引入方式

  1. html中实现多sheet的切换,并将数据显示到div

    <a-radio-group :value="sheetActive" button-style="solid" @change="changeSheet"> <a-radio-button v-for="(item,index) in sheetNames" :key="index" :value="item">{{item}}</a-radio-button> </a-radio-group>

    api(option).then((res)=>{
    ...
    this.initExcelPreview(res.data)
    });

    /**
    * 表格数据预览
    /
    initExcelPreview(blob) { // 接口返回blob
    try {
    const _this = this
    let fr = new FileReader();
    fr.readAsArrayBuffer(file);
    fr.addEventListener("loadend",(e) => {
    let buffer = e.target.result;
    const workbook = XLSX.read(buffer, {type: 'array'})
    const sheetNames = workbook.SheetNames // 工作表名称集合
    _this.workbook = workbook
    _this.sheetNames = sheetNames
    _this.sheetActive = sheetNames[0]
    _this.getTable(sheetNames[0])
    },false);
    } catch (e) {
    ...
    }
    },
    /
    *
    * 根据工作表名称获取数据
    * @param sheetName
    */
    changeSheetTable(e){
    let sheetName =e.target.value
    this.sheetActive =sheetName
    this.getTable(sheetName)
    },
    getTable(sheetName) {
    try {
    const worksheet = this.excel.workbook.Sheets[sheetName]
    let htmlData = XLSX.utils.sheet_to_html(worksheet, {header: '', footer: ''})
    this.activeTable = htmlData
    } catch (e) {
    ...
    }
    },

相关推荐
万物得其道者成6 分钟前
React Zustand状态管理库的使用
开发语言·javascript·ecmascript
小白小白从不日白7 分钟前
react hooks--useReducer
前端·javascript·react.js
下雪天的夏风20 分钟前
TS - tsconfig.json 和 tsconfig.node.json 的关系,如何在TS 中使用 JS 不报错
前端·javascript·typescript
青稞儿25 分钟前
面试题高频之token无感刷新(vue3+node.js)
vue.js·node.js
diygwcom31 分钟前
electron-updater实现electron全量版本更新
前端·javascript·electron
volodyan34 分钟前
electron react离线使用monaco-editor
javascript·react.js·electron
^^为欢几何^^43 分钟前
lodash中_.difference如何过滤数组
javascript·数据结构·算法
Hello-Mr.Wang1 小时前
vue3中开发引导页的方法
开发语言·前端·javascript
程序员凡尘1 小时前
完美解决 Array 方法 (map/filter/reduce) 不按预期工作 的正确解决方法,亲测有效!!!
前端·javascript·vue.js
编程零零七5 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql