前端使用WPS WebOffice 做在线文档预览与编辑

先附上官网 WebOffice SDK

1、在下面这个地方找到jdk,然后下载

按照

2、只需要把jdk下载下来,放到项目中,然后引入到项目中就可以了,在wps 官网创建个应用,然后把appId放到代码中就可以了,等待后端把回调搞完,剩下的都是交给后端就可以了,接口报500,或者403都是后端搞,编辑权限和可读权限也是后端搞的

3、全部代码

javascript 复制代码
<template>
  <div id="wps" ref="iframe"></div>
</template>

<script>
let WebOfficeSDK = require("@/utils/web-office-sdk-solution-v2.0.7.cjs.js");
export default {
  name: "tptOffice",
  data() {
    return {
    };
  },
  watch: {
    $route: {
      handler(to, from) {
        if (to.query.id != undefined) {
          this.init(to.query.id, to.query.officeType);
        }
        if (from?.path == "/tpt/office") {
          this.instance.destroy();  //wps自身的销毁
          //因为离开的时候外层的标签还在,所以加了这个获取类名删除
          const containers = document.getElementsByClassName(
            "web-office-default-container"
          );
          Array.from(containers).forEach((container) => {
            container.parentNode?.removeChild(container);
          });
        }
      },
      immediate: true,
    },
  },
  methods: {
    async init(fileId) {
      const ele = document.getElementById("wps");
      this.instance = await WebOfficeSDK.init({
        officeType: 'w',    // 文件类型
        appId: "XXXXXXXXXXXXXXXX",
        fileId: fileId,
        mount: ele,
        mode: "normal",
        token: "",
      });
    },
  },
};
</script>

<style lang="scss">

</style>

4、在运行中发现有点问题,如果是在页面中套用的话,会占满全屏,左侧有菜单的话,会有遮挡,没有找到好的方法,

相关推荐
aha-凯心31 分钟前
前端学习 vben 之 axios interceptors
前端·学习
熊出没1 小时前
Vue前端导出页面为PDF文件
前端·vue.js·pdf
VOLUN1 小时前
Vue3项目中优雅封装API基础接口:getBaseApi设计解析
前端·vue.js·api
用户99045017780091 小时前
告别广告干扰,体验极简 JSON 格式化——这款工具让你专注代码本身
前端
前端极客探险家1 小时前
告别卡顿与慢响应!现代 Web 应用性能优化:从前端渲染到后端算法的全面提速指南
前端·算法·性能优化
袁煦丞2 小时前
【局域网秒传神器】LocalSend:cpolar内网穿透实验室第418个成功挑战
前端·程序员·远程工作
江城开朗的豌豆2 小时前
Vuex数据突然消失?六招教你轻松找回来!
前端·javascript·vue.js
好奇心笔记2 小时前
ai写代码随机拉大的,所以我准备给AI出一个设计规范
前端·javascript
江城开朗的豌豆2 小时前
Vue状态管理进阶:数据到底是怎么"跑"的?
前端·javascript·vue.js
用户21411832636022 小时前
dify案例分享-Dify v1.6.0 重磅升级:双向 MCP 协议引爆 AI 生态互联革命
前端