vue2实现word在线预览

实现附件在线预览是一个很常用的功能,这次正好碰到这样的需求,记录一下自己实现的过程。

首先是插件的选择,网上实现预览的方法主要有两种,一个是vue-office插件,另一个是docx-preivew插件。看网上其他网友的教程都能够实现文件的在线预览。

选择一:vue-office插件

vue-office官网地址:docx文件预览 | vue-office

不知道是不是因为自己vue版本太低不兼容这个插件,还是其他原因,按照方法怎么都实现不了文件的预览。(项目的vue版本是2.5.17,如果有遇到类似情况解决了的,欢迎指教)

选择二:docx-preivew插件

参考文章:docx-preview在vue内的使用_vue docx-preview-优快云博客

第一种方式实现不了,就选择了第二种。第二个插件主要的问题就是版本的选择。一开始直接无脑操作根据命令(npm i docx-preview)安装插件:

结果出事了。我的vue版本过低,不能直接使用最新版本的docx-preivew插件。后面终于,在网上找到类似的问题,需要安装指定版本的插件,命令:

npm i docx-preview@0.1.20

有两种实现方法 :

一、上传文件进行预览

    <el-dialog
      title="文件预览"
      :visible="dialogVisible"
      show-close
      append-to-body
      width="60%"
      :before-close="cancelDialog"
    >
      <input type="file" @change="handleFileChange" />
      <div class="container" ref="container" id="container"></div>
      <div slot="footer" class="dialog-footer tc">
        <button class="btn-submit btn-submit-sm" @click="cancelDialog()">关闭</button>
      </div>
    </el-dialog>
    async handleFileChange(e){
      const file = e.target.files[0];
      const blob = await this.fileToBlob(file);
      this.preview(blob,this.$refs.container,this.$refs.container);
    },
    fileToBlob(file) {
      return new Promise((resolve,) => {
        let reader = new FileReader();
        reader.readAsArrayBuffer(file);
        let blob = null;
        reader.onload = (e) => {
          if (typeof e.target.result === "object") {
            blob = new Blob([e.target.result]);
          } else {
            blob = e.target.result;
          }
          resolve(blob);
        };
      });
    },
    async preview(blob,createEl,styleEl) {
      await renderAsync(
        blob, // could be any type that supported by JSZip.loadAsync
        createEl, //element to render document content,
        styleEl, //element to render document styles, numbeings, fonts. If null, bodyContainer will be used.
        {
          className: "docx", //class name/prefix for default and document style classes
          inWrapper: true, //enables rendering of wrapper around document content
          ignoreWidth: false, //disables rendering width of page
          ignoreHeight: false, //disables rendering height of page
          ignoreFonts: false, //disables fonts rendering
          breakPages: true, //enables page breaking on page breaks
          ignoreLastRenderedPageBreak: true, //disables page breaking on lastRenderedPageBreak elements
          experimental: false, //enables experimental features (tab stops calculation)
          trimXmlDeclaration: true, //if true, xml declaration will be removed from xml documents before parsing
          useBase64URL: false, //if true, images, fonts, etc. will be converted to base 64 URL, otherwise URL.createObjectURL is used
          useMathMLPolyfill: false, //@deprecated includes MathML polyfills for chrome, edge, etc.
          renderChanges: false, //enables experimental rendering of document changes (inserions/deletions)
          renderHeaders: true, //enables headers rendering
          renderFooters: true, //enables footers rendering
          renderFootnotes: true, //enables footnotes rendering
          renderEndnotes: true, //enables endnotes rendering
          debug: false, //enables additional logging
        },
      );
    },

实现效果:

二、后端提供接口下载文件后预览 

    <el-button
       @click="toPreView($event, row)"
       type="text"
       class="pd-0 btn-table-wid2"
       >预览
    </el-button>

    <el-dialog
      title="文件预览"
      :visible="dialogVisible"
      show-close
      append-to-body
      width="60%"
      :before-close="cancelDialog"
    >
      <div class="container" ref="container" id="container"></div>
      <div slot="footer" class="dialog-footer tc">
        <button class="btn-submit btn-submit-sm" @click="cancelDialog()">关闭</button>
      </div>
    </el-dialog>
  created() {
     this.previewFile(this.docId);
  },
  methods: {
    previewFile() {
      const inParam = {
        DOC_ID: this.docId,
        STAFF_NAME: this.$store.getters.staffName,
        SYS_USER_CODE: this.$store.getters.systemUserCode
      };
      this.$preview(this.mciApi.common.file.previewFile, {
        ...inParam
      },false).then(r => {
        this.preview(r,this.$refs.container,this.$refs.container);
      })
    },
    async preview(blob,createEl,styleEl) {
      await renderAsync(
        blob, // could be any type that supported by JSZip.loadAsync
        createEl, //element to render document content,
        styleEl, //element to render document styles, numbeings, fonts. If null, bodyContainer will be used.
        {
          className: "docx", //class name/prefix for default and document style classes
          inWrapper: true, //enables rendering of wrapper around document content
          ignoreWidth: false, //disables rendering width of page
          ignoreHeight: false, //disables rendering height of page
          ignoreFonts: false, //disables fonts rendering
          breakPages: true, //enables page breaking on page breaks
          ignoreLastRenderedPageBreak: true, //disables page breaking on lastRenderedPageBreak elements
          experimental: false, //enables experimental features (tab stops calculation)
          trimXmlDeclaration: true, //if true, xml declaration will be removed from xml documents before parsing
          useBase64URL: false, //if true, images, fonts, etc. will be converted to base 64 URL, otherwise URL.createObjectURL is used
          useMathMLPolyfill: false, //@deprecated includes MathML polyfills for chrome, edge, etc.
          renderChanges: false, //enables experimental rendering of document changes (inserions/deletions)
          renderHeaders: true, //enables headers rendering
          renderFooters: true, //enables footers rendering
          renderFootnotes: true, //enables footnotes rendering
          renderEndnotes: true, //enables endnotes rendering
          debug: false, //enables additional logging
        },
      );
    },
    cancelDialog(){
      this.$emit('cancelDialog');
    },
  }

注意:

1、this.$preview 是封装的post请求方法,需要设置 responseType: 'blob'

2、this.mciApi.common.file.previewFile 是后台提供的文件下载接口,返回文件流数据,请求成功后将文件流转换成 blob 类型,进行文件预览。

3、blobconst blob = new Blob([content], { type: 'application/pdf' });

实现效果:

### 回答1: 要实现Java Vue实现Word在线预览,可以通过以下步骤: 1. 在Java后端,使用Apache POI库来读取Word文档内容。POI库可以解析Word文档的各种元素,例如段落、表格、图片等。 2. 将读取到的Word文档内容以HTML格式返回给Vue前端。可以使用POI库提供的API将Word内容转换成HTML格式,然后通过Java后端将HTML内容返回给前端。 3.Vue前端,使用相应的组件来渲染并显示HTML内容。可以使用著名的富文本编辑器Quill或者其他类似的库,将返回的HTML内容进行渲染,以实现Word文档的显示。 4.Vue前端,添加相应的控件和功能来支持在线预览Word文档。可以添加双击文档打开、缩放、左右滚动等交互功能,以提升用户体验。 5.Vue前端,添加样式和布局来美化页面。可以采用CSS框架如Bootstrap或Element UI来实现页面的美化和响应式布局,提供更好的用户界面。 需要注意的是,在这个过程中,Java后端负责处理Word文档的读取和转换,将其转化为HTML格式。而Vue前端负责将这个HTML内容进行渲染和显示,提供给用户在线预览的功能。这样,用户就可以通过浏览器直接在线预览Word文档了。 ### 回答2: 要实现Java Vue实现Word在线预览,可以通过以下步骤进行: 1. 首先,使用Vue框架构建前端页面。可以使用Vue的脚手架工具来创建项目,并在项目中安装所需的依赖项(如axios用于发送HTTP请求,element-ui或其他UI库用于页面布局等)。 2.Vue前端页面中创建一个组件,用于上传Word文件。可以使用HTML的`input`元素,并为其添加`type="file"`,当用户选择Word文件时,会触发相应的事件。 3.Vue组件中使用axios发送POST请求,将Word文件提交给后端。可以使用axios的`FormData`对象来创建一个表单对象,并将Word文件附加到表单中。 4. 在后端使用Java编写API,用于接收前端提交的Word文件。可以使用Spring Boot框架来搭建Java后端。在API中,使用Java的文件处理功能将接收到的Word文件保存到服务器本地的某个目录中。 5. 使用Java的Apache POI库来解析Word文件。Apache POI提供了对Word文件的读取和操作功能,在后端使用POI库来读取Word文件的内容。 6. 后端将读取到的Word文件内容返回给前端,可以将内容转换为HTML格式,并将其嵌入到前端页面中的一个`<iframe>`元素中。 7. 前端收到后端返回的HTML内容后,使用`<iframe>`元素将其展示在页面中。可以通过设置`<iframe>`元素的`srcdoc`属性,将HTML内容嵌入其中,并通过CSS样式设置适当的宽度和高度。 8. 最后,用户就可以在前端页面中预览上传的Word文件了。可以通过滚动页面来查看整个文件内容,或者自定义一些导航按钮或操作来进行文件的查看和操作。 通过以上步骤,就可以实现Java Vue实现Word在线预览的功能了。要注意的是,这只是一个简单的实现示例,具体的实现方式可能因具体项目需求而有所差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值