vue 使用vue-office预览word、excel,pdf同理

在此,我只使用了docx和excel, pdf我直接使用的iframe进行的展示就不作赘述了

java 复制代码
//docx文档预览组件
npm install @vue-office/docx

//excel文档预览组件
npm install @vue-office/excel

//pdf文档预览组件
npm install @vue-office/pdf

如果是vue2.6版本或以下还需要额外安装 @vue/composition-api

java 复制代码
npm install @vue/composition-api/
复制代码
<template>
  <div>
    <input
      id="file"
      ref="files"
      type="file"
      @change="changeHandle"
      multiple="multiple"
    />

    <!-- accept=".doc,.docx,.pdf,.ai,.psd,.xlsx,.xls" -->

    <!-- <vue-office-docx :src="src" @rendered="renderingCompleted" /> -->
    <vue-office-excel
      style="flex: 1; height: 0"
      v-show="src"
      :src="src"
      @rendered="renderingCompleted"
    />
  </div>
</template>

<script>
//引入VueOfficeDocx组件
import VueOfficeDocx from "@vue-office/docx";
//引入相关样式
import '@vue-office/docx/lib/index.css'
import VueOfficeExcel from "@vue-office/excel";
import '@vue-office/excel/lib/index.css'
export default {
  data() {
    return {
      src: "",
    };
  },
  components: {
    VueOfficeDocx,
    VueOfficeExcel,
  },
  mounted() {
    //赋值文档路径 此目录可以是http地址,也可以是本地文件
    //   const src = ref("./src/assets/docx/test.docx");
  },
  methods: {
    // 获取文件 这里是使用的 vue3.0 语法
    changeHandle(event) {
      console.log(event.target.files[0]);

      const file = event.target.files[0];

      let fileReader = new FileReader();
      fileReader.readAsArrayBuffer(file);
      fileReader.onload = () => {
        this.src = fileReader.result;
      };

        // const blob = new Blob([file], { type: "application/pdf;charset=utf-8" });
        // const blob = new Blob([file], { type: file.type });
        // this.src = window.URL.createObjectURL(blob); //这里是通过blob拿到url
        console.log("src--", this.src);
    },
    renderingCompleted() {
      console.log("渲染完成");
    },
  },
};
</script>

<style>
</style>

参考:

1、vue + vue-office 实现多种文件(docx、excel、pdf)的预览

2、vue 预览word、excel、pdf文档 vue-office(VueOfficeDocx、VueOfficeExcel、VueOfficePdf)

3、vue 实现 word/excel/ppt/pdf 等文件格式预览操作

4、npm官网解释vue-office

相关推荐
猩兵哥哥2 小时前
前端面向对象设计原则运用 - 策略模式
前端·javascript·vue.js
EMT3 小时前
在 Vue 项目中使用 URL Query 保存和恢复搜索条件
javascript·vue.js
我是日安3 小时前
从零到一打造 Vue3 响应式系统 Day 9 - Effect:调度器实现与应用
前端·vue.js
鹏多多3 小时前
深入解析vue的keep-alive缓存机制
前端·javascript·vue.js
用户516816614584120 小时前
Vue Router 路由懒加载引发的生产页面白屏问题
vue.js·vue-router
前端缘梦20 小时前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
Simon_He20 小时前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
王同学QaQ1 天前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
华仔啊1 天前
基于 RuoYi-Vue 轻松实现单用户登录功能,亲测有效
java·vue.js·后端
葡萄城技术团队1 天前
从100秒到10秒的性能优化,你真的掌握 Excel 的使用技巧了吗?
excel