使用vue-office预览word文档的功能详解

 更新时间:2025年09月28日 15:52:08   作者:Bluecook  
这篇文章主要为大家详细介绍了如何使用vue-office预览word文档的功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

本文将介绍如何使用vue-office来预览word文档,它支持多种文件(docx、pdf、excel)预览的vue组件套装,支持vue2/3。

安装

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

使用实例

文档预览场景大致可以分为两种: 有文档网络地址,比如 https://***.docx 文件上传时预览,此时可以获取文件的ArrayBuffer或Blob

docx文档的预览

这里主要介绍如何使用文件的blob来预览,(因为上一节介绍了通过easy-poi来导出word文档)。我这里使用的vue组件库是antdv,如何你使用的是其他的可以对相关的进行替换

<template>
  <a-button @click="handlePreview" :loading="loading">导出文档</a-button>
  <a-drawer
      v-model:open="open"
      class="custom-class"
      width="80%"
      root-class-name="root-class-name"
      :root-style="{ color: 'blue' }"
      style="color: red"
      title="预览"
      placement="right"
      @after-open-change="afterOpenChange"
  >
    <template #extra>
      <a-button style="margin-right: 8px" @click="handleDownload">下载</a-button>
    </template>
    <vue-office-docx :src="docx" @rendered="rendered"/>
  </a-drawer>
</template>
<script setup>
//引入VueOfficeDocx组件
import VueOfficeDocx from '@vue-office/docx'
//引入相关样式
import '@vue-office/docx/lib/index.css'
import {exportWord} from "@/api/exportWord/index.js";
import {ref} from "vue";

const docx = ref('')
const open = ref(false)
const loading = ref(false)
const handlePreview = () => {
  loading.value = true
  exportWord({}).then(res => {
    const url = window.URL.createObjectURL(new Blob([res], {type: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'}));
    docx.value = url;
    open.value = true
  }).finally(() => {
    loading.value = false
  })
}

const rendered = () => {
  console.log('rendered')
}

const afterOpenChange = () => {
  console.log('afterOpenChange')
}

const handleDownload = () => {
  // 获取该word文档并下载
  const link = document.createElement('a');
  link.href = docx.value;
  link.setAttribute('download', 'export.docx'); // 设置下载文件名
  document.body.appendChild(link);
  link.click();
  document.body.removeChild(link);
}
</script>
<style scoped>
:deep(.docx-wrapper) {
  background-color: #ffffff;
}

:deep(.docx) {
  width: 100% !important;
}
</style>

import {exportWord} from "@/api/exportWord/index.js";引入的是向后端发生请求接口:(注意这里一定要配置responseType: 'blob')

import http from "@/utils/server/http.js";

export const exportWord = (data) => {
    return http.post('/exportWord', data, {responseType: 'blob'})
}

实际预览的效果

使用vue- Office,可以非常的简单的去预览word文档。 

到此这篇关于使用vue-office预览word文档的功能详解的文章就介绍到这了,更多相关vue预览word内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue实现视频全屏切换功能

    vue实现视频全屏切换功能

    这篇文章主要为大家详细介绍了如何使用vue实现视频全屏切换的功能,文中的示例代码讲解详细, 具有一定的借鉴价值,有需要的小伙伴可以参考一下
    2023-11-11
  • Vue获取图片MD5的方法详解

    Vue获取图片MD5的方法详解

    计算图片的MD5可以将其作为图片的唯一标识,从而优化对图片的存储和检索效率,本文主要介绍了Vue获取图片MD5的常用方法,感兴趣的可以了解下
    2024-12-12
  • 基于Vue3实现一个简历生成工具

    基于Vue3实现一个简历生成工具

    本文介绍如何从零开始构建一个基于 Vue3 + Markdown 的在线简历生成工具,支持实时编辑预览、模板切换、自定义样式配置以及导出为 PDF,感兴趣的小伙伴可以参考阅读本文
    2025-07-07
  • vue cli升级webapck4总结

    vue cli升级webapck4总结

    这篇文章主要介绍了vue cli升级webapck4的步骤以及需要注意的地方,大家可以跟着操作学习下。
    2018-04-04
  • 详解如何实现Element树形控件Tree在懒加载模式下的动态更新

    详解如何实现Element树形控件Tree在懒加载模式下的动态更新

    这篇文章主要介绍了详解如何实现Element树形控件Tree在懒加载模式下的动态更新,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04
  • 谈谈因Vue.js引发关于getter和setter的思考

    谈谈因Vue.js引发关于getter和setter的思考

    最近因为公司的新项目决定使用Vue.js来做,但在使用的过程中发现了一个有趣的事情,因为发现的这个事情展开了一些对于getter和setter的思考,具体是什么下面通过这篇文章来一起看看吧,有需要的朋友们可以参考学习。
    2016-12-12
  • vue实现数字加逗号分隔

    vue实现数字加逗号分隔

    在Vue项目中,对数字进行格式化,实现带小数的数字三位一分隔的效果,可以通过自定义过滤器来实现,使用JavaScript的toLocaleString方法可以方便地将数字转换成带逗号的格式
    2024-10-10
  • 一篇超完整的Vue新手入门指导教程

    一篇超完整的Vue新手入门指导教程

    这篇文章主要给大家介绍了关于Vue入门的相关资料,是一篇超完整的Vue入门教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • 教你轻松解决Vue Dialog弹窗诟病

    教你轻松解决Vue Dialog弹窗诟病

    弹窗经常被使用在一些表单的增删改查啊,或者弹出一些提示信息等等,这篇文章主要给大家介绍了关于Vue Dialog弹窗诟病解决的相关资料,需要的朋友可以参考下
    2023-01-01
  • 基于Vue和ECharts实现定时更新与倒计时功能的实战分享

    基于Vue和ECharts实现定时更新与倒计时功能的实战分享

    在前端开发中,动态数据展示和用户交互是构建现代 Web 应用的核心需求之一,在本篇博客中,我们将通过一个简单的案例,展示如何在 Vue 中结合 ECharts 实现一个定时更新和倒计时功能,用于实时监控和数据可视化,需要的朋友可以参考下
    2025-01-01

最新评论