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

相关推荐
落魄江湖行几秒前
进阶篇二 Nuxt4 渲染模式:SSR/SSG/CSR 怎么选
前端·vue.js·typescript·nuxt4
M宝可梦4 分钟前
ReAct 与 LLM Agentic 范式:从推理到行动的完整技术科普
前端·react.js·前端框架
x-cmd6 分钟前
[260416] 谷歌 Chrome 推出 Skills 功能!帮你保存、复用提示词
前端·chrome·ai·自动化·agent·x-cmd·skill
色空大师7 分钟前
【Linux-安装nginx】
linux·运维·前端·nginx·部署
董董灿是个攻城狮11 分钟前
封了几百万个账号的 Claude, 路走窄了
前端
Ruihong27 分钟前
你的 Vue 3 TS 类型声明,VuReact 会处理成什么样的 React?
vue.js·react.js·面试
heytoo27 分钟前
同一个模型,为什么结果差10倍?差的不是模型
前端·agent
霪霖笙箫28 分钟前
「JS全栈AI学习」九、Multi-Agent 系统设计:架构与编排
前端·面试·全栈
慕斯fuafua29 分钟前
CSS——定位
前端·css
Cache技术分享30 分钟前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
前端·后端