简易Excel表与PDF预览实现

本地Excel表预览(纯前端):

采用XLSX的插件库(npm)

是基于SheetJs的Excel分析库

npm地址:www.npmjs.com/package/xls...

复制代码
npm install xlsx

原理是将excel表分析成对应的html格式(异步)

文件通过上传组件获取到对应的File格式,传给excel表处理函数file2Preview

js 复制代码
import * as XLSX from 'xlsx';
// 返回一个异步,并且返回Excel文件读取后的结果
export const file2Preview = (file: File) => {
    return new Promise((resolve) => {
        // 读取文件流
        const reader = new FileReader()
        // 文件加载
        reader.onload = (e) => {
            const data = e.target?.result
            const workbook = XLSX.read(data, {
                    type: "binary",
                    cellDates: true,
                })
                // execl表格中的第一页
                const worksheet = workbook.Sheets[workbook.SheetNames[0]];
                // 处理成html格式
                const html = XLSX.utils.sheet_to_html(worksheet)
                resolve(html)
        }
            reader.readAsBinaryString(file)//读取二进制字符串
}

返回的就是被分析成html格式的excel表

js 复制代码
<template>
    <div v-html="html"></div>
</template>
js 复制代码
<script setup>
    const html = ref("");
    //文件上传获取文件file
    const handleChange = async (info) => {
  html.value = await file2Preview(info.file.originFileObj);
};
</script>

简单预览:

PDF文件预览(本地与远程地址URL):

采用vue-office/PDF的插件库

vue-office是一个支持多种文件(docx、.xlsx、pdf)预览的vue组件库,支持vue2和vue3

官方地址:501351981.github.io/vue-office/...

bash 复制代码
npm install @vue-office/pdf vue-demi

这个插件库支持两种预览方式,一种是给远程地址URL,另一种是给ArrayBuffer

ArrayBuffer方式

js 复制代码
// 返回一个异步,并且PDF文件返回读取后的结果
export const pdf2Preview = (file: File) => {
    return new Promise((resolve) => {
        // 读取文件流
        const reader = new FileReader()
        // 文件加载
        reader.onload = (e) => {
            const data = e.target?.result
            resolve(data);
        }
        reader.readAsArrayBuffer(file)
    })
}

直接将ArrayBuffer传入vue-office-pdf组件中

js 复制代码
<template>
    <vue-office-pdf v-model:src="pdf_src"  />
</template>
js 复制代码
<script setup>
    const pdf_src = ref("");
    //文件上传获取文件file
    const handleChange = async (info) => {
        pdf_src.value = await pdf2Preview(info.file.originFileObj);
    };
</script>

简单预览:

远程地址URL方式

直接将pdf_src换成对应的远程地址就可以

相关推荐
麦麦大数据6 小时前
F036 vue+flask中医热性药知识图谱可视化系统vue+flask+echarts+mysql
vue.js·python·mysql·flask·可视化·中医中药
技术钱7 小时前
vue3前端解析excel文件
前端·vue.js·excel
韩立学长7 小时前
【开题答辩实录分享】以《智慧校园勤工俭学信息管理系统的设计与实现》为例进行答辩实录分享
vue.js·spring boot·微信小程序
@PHARAOH7 小时前
HOW - localstorage 超时管理方案
前端·javascript·vue.js
DokiDoki之父8 小时前
前端速通—Vue_简介 & 第一个Vue程序 & el:挂载点 & data:数据对象 & Vue指令
javascript·vue.js·ecmascript
Crystal32810 小时前
app里video层级最高导致全屏视频上的操作的东西显示不出来的问题
前端·vue.js
weixin_4454766810 小时前
Vue+redis全局添加水印解决方案
前端·vue.js·redis
CptW11 小时前
Vue3 的“批量渲染”机制
vue.js·面试
计算机学姐11 小时前
基于SpringBoo+Vue的医院预约挂号管理系统【个性化推荐算法+可视化统计】
java·vue.js·spring boot·mysql·intellij-idea·mybatis·推荐算法
计算机学姐12 小时前
基于微信小程序的奶茶店点餐平台【2026最新】
java·vue.js·spring boot·mysql·微信小程序·小程序·mybatis