|
@@ -0,0 +1,63 @@
|
|
|
+<template>
|
|
|
+ <div class="doc">
|
|
|
+ <!-- 此div用来加载PageOffice客户端控件,其中div的高宽及位置就决定了控件的大小及位置 -->
|
|
|
+ <div style="width:auto; height:900px;" v-html="poHtmlCode"></div>
|
|
|
+ 2323
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+
|
|
|
+ <script>
|
|
|
+ import request from '@/utils/request'
|
|
|
+ export default {
|
|
|
+ name: 'DocView',
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ poHtmlCode: '',
|
|
|
+ open_params: '',
|
|
|
+ }
|
|
|
+ },
|
|
|
+ created: function () {
|
|
|
+ //使用pageofficectrl.WindowParams获取获取父页面(此项目中为:HomeView.vue)中POBrowser.openWindow()方法的第三个参数的值,获取到的值为string类型
|
|
|
+ this.open_params = JSON.parse(pageofficectrl.WindowParams);
|
|
|
+ // 请求后端打开文件
|
|
|
+ this.openFile().then(response => {
|
|
|
+ this.poHtmlCode = response;
|
|
|
+ }
|
|
|
+ );
|
|
|
+
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ OnPageOfficeCtrlInit() {
|
|
|
+ //PageOffice的初始化事件回调函数,您可以在这里添加自定义按钮
|
|
|
+ pageofficectrl.Caption = this.open_params.fileName;
|
|
|
+ pageofficectrl.AddCustomToolButton("保存", "Save", 1);//其中"Save"对应methods中的Save()函数,并且需要在mounted中挂载。
|
|
|
+ },
|
|
|
+ Save() {
|
|
|
+ //使用SaveFilePage属性设置后端保存方法的Controller路由地址,这个地址必须从"/"开始,并且也可以向此路由地址传递json字符串参数,示例如下:
|
|
|
+ let saveFileUrl = "/doc/saveFile";
|
|
|
+ let paramValue = new URLSearchParams(this.open_params);//为了简单起见,这里直接使用打开时的参数。
|
|
|
+ pageofficectrl.SaveFilePage = `${saveFileUrl}?${paramValue.toString()}`;
|
|
|
+ //在这里写您保存前的代码
|
|
|
+ pageofficectrl.WebSave();
|
|
|
+ //在这里写您保存后的代码,比如判断保存结果pageofficectrl.CustomSaveResult
|
|
|
+ //alert(pageofficectrl.CustomSaveResult);
|
|
|
+ },
|
|
|
+ AfterDocumentOpened() {
|
|
|
+ //在这里写您文档打开后自动触发的代码
|
|
|
+ },
|
|
|
+ openFile() {
|
|
|
+ //发起GET请求到后端Controller的/doc/openFile路由
|
|
|
+ return request({
|
|
|
+ url: '/doc/openFile',
|
|
|
+ method: 'get',
|
|
|
+ params: this.open_params
|
|
|
+ })
|
|
|
+ }
|
|
|
+ },
|
|
|
+ mounted: function () {
|
|
|
+ //将当前页面methods中定义的函数挂载到PageOffice控件,例如控件触发的事件、自定义按钮触发的函数。
|
|
|
+ window.POPageMounted = this;//此行必须
|
|
|
+ }
|
|
|
+ }
|
|
|
+ </script>
|
|
|
+
|