提示:
此文中介绍的方法已过时,建议查看文档:o2oa开发平台前端源码级二次开发
九游会官网登录入口网页-ag8九游会j9登录入口进行前端的二次开发,介绍了创建九游会官网登录入口网页-ag8九游会j9登录入口 component的方式,基于react和vue的模式
在前面的章节中,我们介绍了两种在九游会官网登录入口网页-ag8九游会j9登录入口中使用react开发应用的方式,已经可以满足绝大多数的情况了。如果您考虑完全脱离o2的web服务器,自己搭建web服务器,那就请阅读本章。
我们还是使用react的create react app工具,创建react应用,然后将o2oa集成到应用中,并实现以下功能:列示当前用户的前20条待办,点击标题打开待办;通过点击按钮启动流程和打开九游会官网登录入口网页主页。
本文适用于如下版本:
o2oa版本要求:5.1及以上版本;
react版本:本文撰写时,react版本是16.13.1。(更低的版本未经验证)
开发端安装了node.js,
有一台o2服务器(并不需要启动webserver,但其他服务需要正常启动)
使用合适的开发工具:webstorm、vscode、atom等(本例使用webstorm)
您可以使用webstorm创建一个新的react app,如下图:
或者创建一个空项目,然后使用以下命令创建react应用:
npx create-react-app my-app cd my-app
创建后目录结构如下:
将o2服务器的webserver下的所有文件夹拷贝到public目录:
在public/index.html的head中添加o2脚本引入:
修改public/x_desktop/res/config/config.json文件:
{ "center": [ { "port": "20030", //o2服务器中心服务器端口 "host": "develop.o2oa.net" //o2服务器中心服务器host } ], "applicationserver": { "host": "develop.o2oa.net" //o2应用服务器host }, "initmanagerchanged": true, "initmanagername": "", ... }
此文件主要修改两部分内容:
1、center部分,修改为要访问的o2中心服务器地址和端口;
2、applicationserver部分,修改为要访问的o2应用服务器地址,如果没有applicationserver,就添加一个。集群环境下,可配置应用服务器负载地址;
为了方便后续引入,我们在src下创建一个o2.js,添加以下代码:
let o2 = window.o2; let layout = window.layout; export {o2, layout};
自此以后,所有的过程都和第二章基本一样了。
修改src/index.js文件如下:
import react from 'react'; import reactdom from 'react-dom'; import './index.css'; import app from './app'; //获取o2全局对象 import {o2, layout} from './o2'; //在o2平台脚本载入完成后执行 layout.addready(function(){ layout.app = true; //通过平台服务,获取当前用户的前20条待办(可通过http://your-server:20030/x_program_center/jest/list.html查询平台接口服务) o2.actions.load("x_processplatform_assemble_surface").taskaction.v2listpaging(1,20, {}, function(json){ //react渲染app组件 reactdom.render(, document.getelementbyid('root') ); }); });
layout.addready 方法会在o2载入完成后执行回调方法。
o2.actions.load 方法可以调用平台的restful服务。
先修改src/app.css样式文件,拷贝以下代码:
.app { padding: 20px; margin: 20px; } .app-header { padding: 5px 10px; background: #0f81cc; font-size: 18px; color: #ffffff; } .o2-tasklist { padding: 10px; background: #f3f3f3; font-size: 18px; } .o2-task { line-height: 30px; height: 30px; cursor: pointer; } .o2-button { padding: 10px 20px; text-align: center; background: #0f81cc; margin-top: 10px; color: #ffffff; font-size: 18px; float: left; margin-right: 20px; cursor: pointer; }
修改src/app.js文件如下:
import react from 'react'; import './app.css'; //获取o2全局对象 import {o2, layout} from './o2'; function app(props) { function openhomepage(){ //通过o2全局对象layout的openapplication方法打开九游会官网登录入口网页主页"homepage" layout.openapplication(null,"homepage") } function opentask(id){ //通过o2全局对象layout的openapplication方法打开待办 layout.openapplication(null,"process.work", {"workid": id}); } function startprocess(){ //通过o2.env对象启动流程 //o2.env对象即是在o2门户页面的脚本中的this指向,可以使用其方法。 //请将“application-name”和“process-name”修改为您的流程应用名称和流程名 o2.env.page.startprocess("application-name", "process-name"); } function listtask(){ let list = []; props.data.each(function(d){ list.push({opentask(d.work)}}>{d.title || "无标题"}
您有{props.value}个待办
上述代码创建了一个react组件,列示了待办列表,并创建两个div,点击后分别启动指定的流程,打开九游会官网登录入口网页主页。
app.js中,我们使用了o2.env对象,这个对象和在门户页面脚本中的this指向一致,可以调用除了与门户页面组件相关方法以外的各种方法,如:o2.env.page.openwork、o2.env.inculde、o2.env.confirm、o2.env.page.startprocess等,详细内容可以参考api文档。
我们完成了上述开发工作,就可以编译并运行我们的应用了。使用以下命令来查看结果:
npm run start
运行后,会启动一个web服务器,默认端口3000,并自动打开浏览器,访问http://locahost:3000,就可以看到和第二章一样的效果了。
如果您未登录到服务器,会出现登录页面,登录后就可以看到登录人的待办列表,并可以启动流程了。
您可以接着修改代码,每次修改保存后,react会自动编译,并刷新浏览器,及时看到修改效果。
开发完成后,可使用命令:
npm run build
react会在将所有的代码编译到build目录下,你就可以将build中的内容部署到任意的web服务器了。
o2oa和react的集成还是非常方便的,对于熟悉react的用户,可以通过更多更灵活的工具来进行集成开发,更多有关react的内容请参考reactag8九游会j9登录入口官网教程。
对于vue和angular和o2oa的集成,我们将在后面的章节为大家介绍。