vue2 预览word文件

1. 使用vue-office

父组件调用init方法即,适用于远程url和本地文件

javascript 复制代码
npm install @vue-office/docx vue-demi
javascript 复制代码
<template>
  <el-dialog
    v-el-drag-dialog
    :visible.sync="previewOpen"
    :close-on-click-modal="false"
    append-to-body
    custom-class="previewDialog"
    @close="closeDialog"
  >
    <vue-office-docx :src="docx" @rendered="rendered" />
  </el-dialog>
</template>
<script>
  import VueOfficeDocx from '@vue-office/docx'
  import axios from 'axios'
  export default {
    components: {
      VueOfficeDocx
    },
    data() {
      return {
        previewOpen: false,
        docx: '' // 远程url地址,本次使用blob文件流转url
      }
    },
    beforeDestroy() {
      if (this.docx) {
        URL.revokeObjectURL(this.docx) // 清除Blob URL
      }
    },
    methods: {
      // 预览
      init(id) {
        axios({
          method: 'get',
          responseType: 'blob',
          url: '' // 自己的服务器,提供的一个word下载文件接口
        }).then((res) => {
          this.previewOpen = true
          this.$nextTick(() => {
            this.docx = window.URL.createObjectURL(res.data)
          })
        })
      },
      rendered() {
        console.log('渲染完成')
      },
      closeDialog() {
        this.previewOpen = false
      }
    }
  }
</script>
<style scoped>
  .previewDialog .el-dialog__headerbtn .el-dialog__close {
    z-index: 2001;
  }
  .word {
    display: block;
  }
</style>

2.使用docx-preview

父组件调用init方法即可,适用于本地文件

javascript 复制代码
npm install docx-preview
javascript 复制代码
<template>
  <el-dialog
    v-el-drag-dialog
    :visible.sync="previewOpen"
    :close-on-click-modal="false"
    append-to-body
    custom-class="previewDialog"
    @close="closeDialog"
  >
    <div class="word">
      <div ref="myfile" />
    </div>
  </el-dialog>
</template>
<script>
  const docx = require('docx-preview')
  import axios from 'axios'
  export default {
    data() {
      return {
        previewOpen: false
      }
    },
    methods: {
      init(id) {
        axios({
          method: 'get',
          responseType: 'blob',
          url: '' // 自己的服务器,提供的一个word下载文件接口
        }).then((res) => {
          this.previewOpen = true
          this.$nextTick(() => {
            docx.renderAsync(res.data, this.$refs.myfile)
          })
        })
      },
      closeDialog() {
        this.previewOpen = false
      }
    }
  }
</script>
<style scoped>
  .previewDialog .el-dialog__headerbtn .el-dialog__close {
    z-index: 2001;
  }
  .word {
    display: block;
  }
</style>
相关推荐
小白学大数据14 小时前
Playwright 爬虫:Python 爬取 JS 渲染的 JSP 网站
开发语言·javascript·爬虫·python·数据分析
不爱说话郭德纲15 小时前
出门在外收到任务,我用 TRAE SOLO 把电脑“叫醒”干活
前端·ai编程
前端Hardy15 小时前
这个前端动画库,火了!
前端·javascript
小林攻城狮15 小时前
Vite项目使用@turbodocx/html-to-docx报错问题排查与解决方案
前端·ai编程
Asmewill15 小时前
LangGraph学习笔记六(Stream流式输出)
前端
哈撒Ki15 小时前
前端性能优化汇总
前端·面试
Asmewill15 小时前
LangGraph学习笔记七(checkpointer)
前端
前端小木屋15 小时前
uniapp与蓝牙设备连接详细步骤
前端·微信小程序
yingyima15 小时前
Go 语言定时任务速查手册:实现延迟与周期任务的高效方法
前端
GISer_Jing15 小时前
WebGL|Three.js渲染管线核心技术解析
java·javascript·webgl