vue onlyoffice在线编辑与预览,文件无法保存问题,始终打开同一文件的问题

主要写一下前端vue的使用,需要后端或运维去弄docker服务,然后给前端一个api地址

在vue的Index.html页面添加这个

<script type="text/javascript" src="http://docker服务器ip:docker服务器端口/web-apps/apps/api/documents/api.js"></script>

onlyoffice文档

在线文档编辑使用页面

<template><div><div id="placeholder"></div></div>
</template><script>
export default {name: 'onlyOffice',data() {return {DocEditor: null,}},mounted() {let obj = this.$route.query;console.log('sjsjsjsjjsjsjsjsjsj')this.init(obj,'mounted')},methods: {init(e,formType){if (this.DocEditor != null) {this.DocEditor.destroyEditor();}let url = e.fileurl;let mode = e.mode || 'view';//有两种模式,edit为编辑模式,view为查看let name = e.name || '文件';let id = e.id;let type = e.type;console.log('拿到的在线编辑文件路径',url,mode,name,id,type)let key = new Date().getTime() + '';//用一个动态key止,防止是一样的let file_name = url.match(/\.([^\.]+)$/)[1];//获取文件后缀let houzhuiType;//根据文件后缀判断其在onlioffice里是用什么类型,这里我只写了常用的几种,需要的可以去看文档添加if(file_name == 'ppt' || file_name == 'pptx'){houzhuiType = 'slide';}else if(file_name == 'xlsx' || file_name == 'xls'){houzhuiType = 'cell';}else{houzhuiType = 'word';}console.log('文件后缀',file_name,houzhuiType)let height = document.documentElement.clientHeight - 60 + 'px';//高度let config = {"document": {"fileType": file_name,//文件类型//主键,onlyOffice会做缓存"key": key,"title": name+file_name,//编辑时显示的名称// 文档地址url"url": url, },"documentType": houzhuiType,//文件类型对应在onlyoffice的类型"height": height,"editorConfig": {"mode": mode, //view为查看,edit为编辑"lang": "zh-CN",//默认为英文版,这里设为中文// 自己后端接受文件流的接口地址,同时自己可以拼接参数传给后端"callbackUrl": process.env.VUE_APP_BASE_URL + `/inspection/reportUpload/docx/save?id=${id}&reportType=${type}`,"user": {"id": "22","name": "fff"},"customization": {//开启保存发送状态=6回调"forcesave": true,"anonymous": {//当前操作用户姓名"label": "工具人"},},},events: {"onDocumentStateChange": this.onDocumentStateChange,"onRequestSaveAs": this.onRequestSaveAs,"onDownloadAs": this.onDownloadAs,"onError": this.error,"onWarning": this.warning,"onAppReady": this.action,},};this.DocEditor = new DocsAPI.DocEditor("placeholder", config);},//onlyoffice加载会执行的方法action(e){console.log('开始')},warning(e) {console.log('警告', e)},error(e) {console.log('错误', e)// this.$message.warning('未知错误')},//缓存到onlyOffice数据库里面的回调onDocumentStateChange(event) {if (event.data) {console.log("````````````The document changed");console.log(event);console.log(event.data);} else {console.log("````````````Changes are collected on document editing service");}},//点击保存按钮的回调,但没有效果onRequestSaveAs(event) {console.log('保存',event)},//下载另存为onDownloadAs(event) {//  let fileType = event.data.fileType;//  let url = event.data.url;//  console.log("ONLYOFFICE Document Editor create file: " + url);},}
}
</script><style scoped></style>

如果一开始提示文件无法保存,那就是callbackUrl有问题,该接口后端接口没走通
在这里插入图片描述

总是打开同一个文件问题,文件路径换了也是打开原来的文件
其实是因为onlyoffice自动缓存了当前这个组件,只要打开过就会缓存起来,第二次打开该页面,mounted周期函数都没执行
解决办法,利用keepalive里的activated方法里重新执行一遍init方法就行

 activated(){console.log('????????????????')let obj = this.$route.query;this.init(obj)},

上面是我自己研究的方法,每次进来就重新走一遍流程,其实好像可以通过修改上面配置里config 里的key值来变换,但我不知道怎么去改,就这样吧,能用就行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/233961.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智能优化算法应用:基于鼠群算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于鼠群算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于鼠群算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.鼠群算法4.实验参数设定5.算法结果6.参考文献7.MA…

【网络安全】—Shell编程入门(1)

文章目录 基础变量概念介绍特殊变量进阶数值计算实践条件测试比较条件判断语句流程控制语句循环语句应用 Shell 是 Unix/Linux 操作系统下的一种命令行解释器&#xff0c;它接收用户输入的命令然后调用相应的程序。我们可以通过 Shell 脚本来自动执行一系列的命令。接下来&…

Logback简介与配置详解

在开发和维护Spring Boot应用程序时&#xff0c;一个强大而灵活的日志框架是至关重要的。Spring Boot默认集成了Logback&#xff0c;一个高性能的Java日志框架。本文将介绍如何配置Logback以满足你的日志记录需求。 Logback简介 官方网址&#xff1a;https://logback.qos.ch/ …

JAVA面试题14

Java中的Lambda表达式是什么&#xff1f; 它有什么作用&#xff1f; 答案&#xff1a;Lambda表达式是一种简洁的语法&#xff0c;用于创建函数式接口的实例。Java中的Lambda表达式可以简化代码、减少冗余的匿名类和提高程序的可读性&#xff0c;支持函数式编程的特性。 什么是…

【C++进阶】继承

一、继承的基本概念及定义 1.1 继承的概念 继承的本质是代码的复用 比如&#xff1a; 学校的师生管理系统 有学生、老师、宿管阿姨等 每个人都有的信息名字、电话 身份证号、年龄、性别等 我们可以发现有些类型是具有共性的 如果每个类都去写&#xff0c;初始化时每个 都要初…

Vault实战(一)-Vault介绍

1 Vault介绍 Vault 是一个基于身份的秘密和加密管理系统。秘密是您想要严格控制访问的任何内容&#xff0c;例如 API 加密密钥、密码和证书。 Vault 提供由身份验证和授权方法控制的加密服务。使用 Vault 的 UI、CLI 或 HTTP API&#xff0c;可以安全地存储和管理、严格控制&a…

FPGA 实现 LeNet-5 卷积神经网络 数字识别,提供工程源码和技术支持

目录 1、前言LeNet-5简洁基于Zynq7020 的设计说明PL 端 FPGA 逻辑设计PS 端 SDK 软件设计免责声明 2、相关方案推荐卷积神经网络解决方案FPGA图像处理方案 3、详细设计方案PL端&#xff1a;ov7725摄像头及图像采集PL端&#xff1a;图像预处理PL端&#xff1a;Xilinx推荐的图像缓…

ASO优化实践经验和改进措施

在积累了大量的实战经验后&#xff0c;小柚总结了一些关于ASO优化的经验给大家分享。共同进步&#xff01;共同学习&#xff01;Fighting&#xff01; 一、关键词研究 关键词研究是ASO优化的基础。在进行关键词研究时&#xff0c;需要了解用户搜索意图、关键词竞争情况和关键…

1265. 数星星(树状数组/蓝桥杯)

题目&#xff1a; 输入样例&#xff1a; 5 1 1 5 1 7 1 3 3 5 5输出样例&#xff1a; 1 2 1 1 0 思路&#xff1a; 树状数组 代码&#xff1a; #include<cstdio> #include<iostream> using namespace std; const int N32010; int n; int tr[N],level[N];int lo…

linux:掌握systemctl命令控制软件的启动和关闭、掌握使用ln命令创建软连接

掌握使用systemctl命令控制软件的启动和关闭 一&#xff1a;systemctl命令&#xff1a; Linux系统很多软件(内置或第三方)均支持使用systemctl命令控制:启动停止、开机自启 能够被systemctl管理的软件一般也称之为:服务 语法: systemctl | start | stop | status | enable …

C++接口类使用Qt的虚信号

项目中封装库的对外接口类&#xff0c;包括Qt的插件框架&#xff0c;希望接口类是一个比较干净的类&#xff0c;不需要继承自Object&#xff0c;与Qt无关系&#xff0c;但又需要它的子类使用Qt的信号和槽机制&#xff0c;则可以如下处理。 接口类&#xff1a; /* 处理请求 */ …

golang实现注册系统服务(Windows、Darwin)

golang实现注册系统服务&#xff08;Windows、Darwin&#xff09; 仓库地址&#xff1a;https://github.com/ziyifast/yiSystemService 使用第三方包&#xff1a;go get “github.com/kardianos/service” 日志库&#xff1a;go get “github.com/sirupsen/logrus” log “gith…

Qt Q_DECL_OVERRIDE

Q_DECL_OVERRIDE也就是C的override&#xff08;重写函数&#xff09;&#xff0c;其目的就是为了防止写错虚函数,在重写虚函数时需要用到。 /* 鼠标按下事件 */ void mousePressEvent(QMouseEvent *event) Q_DECL_OVERRIDE; 参考: Qt Q_DECL_OVERRIDE - 一杯清酒邀明月 - 博客…

Mybatis复习总结

MyBatis是一款优秀的持久层框架&#xff0c;用于简化JDBC的开发 MyBatis本是Apache的一个开源项目&#xff0c;2010年这个项目由apache迁移到了Google&#xff0c;并且改名为 Mybatis&#xff0c;2013年11月迁移至Github。 持久层 指的就是数据访问层&#xff0c;用来操作数…

图用邻接表表示的深度优先和广度优先遍历

邻接表表示法进行深度优先遍历的示例代码&#xff1a; #include <stdio.h> #include <stdlib.h>#define MAX_VERTEX_NUM 100// 边表节点结构体 typedef struct ArcNode {int adjvex; // 邻接顶点下标struct ArcNode* nextarc; // 指向下一个邻…

数组指定部分逆序重放

系列文章目录 进阶的卡莎C++_睡觉觉觉得的博客-CSDN博客数1的个数_睡觉觉觉得的博客-CSDN博客双精度浮点数的输入输出_睡觉觉觉得的博客-CSDN博客足球联赛积分_睡觉觉觉得的博客-CSDN博客大减价(一级)_睡觉觉觉得的博客-CSDN博客小写字母的判断_睡觉觉觉得的博客-CSDN博客纸币(…

pgsql的jsonb相关处理及样例

目录 1、某个字段中包含目标list中的全部使用>&#xff1a; 2、某个字段中包含目标list中任意值使用?|&#xff1a; 3、其他操作样例&#xff1a; 1、某个字段中包含目标list中的全部使用>&#xff1a; SELECT * FROM "public"."t_a" WHERE a::j…

ubuntu 20.04 docker prometheus

ubuntu 20.04 docker https://docs.docker.com/engine/install/ubuntu/ Ubuntu20.04下部署linux资源监控平台&#xff08;docker部署&#xff09;grafanaprometheusnode_exporter&#xff08;docker离线包&#xff09; https://blog.csdn.net/deer_cui/article/details/1340208…

基于ssm物资进销存论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本货物进销管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信息…

day15-动画和路由过渡和切换

&#x1f4da; 目录 介绍介绍 AnimationCurveAnimationControllerTween监听动画 自定义路由切换动画Hero飞行动画交织动画动画切换组件 AnimatedSwitcherAnimatedSwitcher封装 动画过渡组件 本文学习和引用自《Flutter实战第二版》&#xff1a;作者&#xff1a;杜文 1. 介绍 …