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) {
    ...
    }
    },

相关推荐
GISer_Jing8 分钟前
前端学习总结——AI&主流前沿方向篇
前端·人工智能·学习
渣哥17 分钟前
用错注入方式?你的代码可能早就埋下隐患
javascript·后端·面试
尘世中一位迷途小书童18 分钟前
Monorepo 工具大比拼:为什么我最终选择了 pnpm + Turborepo?
前端·架构
一枚前端小能手20 分钟前
🔍 重写vue之ref和reactive
前端·javascript·vue.js
星链引擎22 分钟前
4sapi.com开发者进阶版(技术导向,侧重 “原理 + 最佳实践”)
前端
尘世中一位迷途小书童24 分钟前
2025年了,你还在用传统的多仓库管理吗?Monorepo 架构深度解析
前端·架构
fruge27 分钟前
前端性能优化实践指南:从理论到落地
前端·性能优化
快起来别睡了31 分钟前
用这 9 个 API,我把页面性能干到了 90+
前端
芒果茶叶43 分钟前
深入浅出requestAnimationFrame
前端·javascript·html
歪歪1001 小时前
在哪些场景下适合使用 v-model 机制?
服务器·前端·javascript·servlet·前端框架·js