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

相关推荐
m0_749317527 分钟前
VUE学习
前端·javascript·vue.js·学习
顽疲30 分钟前
从零用java实现 小红书 springboot vue uniapp (9)消息推送功能
java·vue.js·spring boot·uni-app
林涧泣31 分钟前
【Uniapp-Vue3】watch和watchEffect监听的使用
前端·vue.js·uni-app
番茄小酱0011 小时前
select下拉框,首次进入页面没有显示value的情况
前端·javascript·vue.js·vue
LCG元1 小时前
Vue.js组件开发-如何动态更改图表类型
vue.js
顾尘眠2 小时前
element(vue2)表格插槽
javascript·vue.js·elementui
暗暗那2 小时前
Vue演练场基础知识(六)Props传参+Emits事件
前端·javascript·vue.js
顽疲2 小时前
从零用java实现 小红书 springboot vue uniapp (8)个人资料修改 消息页优化
java·vue.js·spring boot·uni-app
背太阳的牧羊人3 小时前
使用 SQL 和表格数据进行问答和 RAG(6)—将指定目录下的 CSV 或 Excel 文件导入 SQLite 数据库
数据库·sql·langchain·sqlite·excel
一念永恒@3 小时前
vue2新增删除
前端·javascript·vue.js