文件预览(pdf word excel ppt等)

前提:都是通过接口获取到的文件流,然后通过以上window.URL.createObjectURL方法将转成url传给组件

  1. @cyntler/react-doc-viewer

通过支持的文件类型可知word、excel、ppt类的有局限性

  1. react-file-viewer
  • docx的文件支持预览,无局限性
  • 应该是xlsx吧? 它的官网写的是xslx,但是无法预览
  1. docx-preview

这个预览docx的效果比react-file-viewer要好

  1. react-excel-renderer

支持xlsxxlscsv

此组件不能直接用于预览,而是拿到文件信息,将其转成二维数组,手动进行渲染,代码如下:

js 复制代码
import React, { useEffect, useState } from 'react'
import { ExcelRenderer } from 'react-excel-renderer'

export default function ExcelViewer(file) {
  const [rows, setRows] = useState([])
  const [cols, setCols] = useState([])

  const handleFile = (file) => {
    ExcelRenderer(file, (err, resp) => {
      if (err) {
        console.error(err)
      } else {
        setCols(resp.cols)
        setRows(resp.rows)
      }
    })
  }

  useEffect(() => {
    if (file) {
      handleFile(file.file)
    }
  }, [file])

  return (
    <div>
      {rows.length > 0 && (
        <div style={{ overflowX: 'auto', marginTop: '20px' }}>
          <table style={{ borderCollapse: 'collapse', width: '100%' }}>
            <thead>
              <tr>
                {cols.map((col, index) => (
                  <th key={index} style={{ border: '1px solid #ddd', padding: '8px' }}>
                    {col.name}
                  </th>
                ))}
              </tr>
            </thead>
            <tbody>
              {rows.map((row, rowIndex) => (
                <tr key={rowIndex}>
                  {row.map((cell, cellIndex) => (
                    <td key={cellIndex} style={{ border: '1px solid #ddd', padding: '8px' }}>
                      {cell}
                    </td>
                  ))}
                </tr>
              ))}
            </tbody>
          </table>
        </div>
      )}
    </div>
  )
}

弊端:样式不空,对于合并单元格以及一些内部样式(链接、字体等)无法进行拿到其信息,也就无法渲染,只能是简单的显示内容,如下图

  1. pptx2html

ppt的预览无法直接通过纯前端实现,可以采用前后端结合的方式实现,后端通过nodeJs + pptx2html,将ppt文件转成html,返回给前端进行渲染

后端示例(Node.js + pptx2html

js 复制代码
const express = require('express');
const pptx2html = require('pptx2html');
const multer = require('multer');
const upload = multer({ dest: 'uploads/' });

app.post('/api/parse-pptx', upload.single('pptx'), async (req, res) => {
  const result = await pptx2html(req.file.path);
  res.json(result.slides);
});

前端示例

jsx 复制代码
function PPTXViewer() {
  const [slides, setSlides] = useState([]);

  const handleUpload = async (e) => {
    const file = e.target.files[0];
    if (!file) return;

    const formData = new FormData();
    formData.append('pptx', file);

    const response = await fetch('/api/parse-pptx', {
      method: 'POST',
      body: formData
    });
    setSlides(await response.json());
  };

  return (
    <div>
      <input type="file" accept=".pptx" onChange={handleUpload} />
      {slides.map((slide, index) => (
        <div key={index} dangerouslySetInnerHTML={{ __html: slide.html }} />
      ))}
    </div>
  );
}
  1. ppt的可以换个思路:ppt转pdf,然后再预览,这样前端可以实现

总结:

pdf:支持

word:仅支持docx

excel: 支持,但是样式有问题

ppt:支持

相关推荐
不会Android的潘潘3 分钟前
受限系统环境下的 WebView 能力演进:车载平台 Web 渲染异常的根因分析与优化实践
android·java·前端·aosp
建军啊7 分钟前
java web常见lou洞
android·java·前端
阳无7 分钟前
宝塔部署的前后端项目从IP访问改成自定义域名访问
java·前端·部署
Galloping-Vijay12 分钟前
解决 WSL2 + Windows Hosts + 开启 VPN 后无法访问本地 Web 服务的问题
前端·windows
wuhen_n29 分钟前
TypeScript的对象类型:interface vs type
前端·javascript·typescript
见路不走!30 分钟前
后端返回Blob文件流,前端实现导出
前端
lindd91191132 分钟前
4G模块应用,内网穿透,前端网页的制作第七讲(智能头盔数据上传至网页端)
前端·后端·零基础·rt-thread·实时操作系统·项目复刻
css趣多多42 分钟前
props,data函数,computed执行顺序
前端·javascript·vue.js
一个不称职的程序猿44 分钟前
构建优雅的 Vue.js 表情包选择器:一个功能丰富且可定制的 Emoji Picker 组件
前端·javascript·vue.js
Charlie_lll1 小时前
学习Three.js--光源Light+轨道控制器OrbitControls
前端·three.js