Vue集成activity工作流

Vue集成activity工作流情景:由于activiti与系统应用主题样式出入较大,协商后决定将activiti的editor-app放在前台。ps:内网开发,无图,凭记忆摘取主要内容。步骤:将activiti放在public即静态目录下。 通过iframe在相应的前台工作流界面引入activiti的model.html(最外层的主html,名字可能有出入)。 mounted时将this,即vuecompo…

大家好,又见面了,我是你们的朋友全栈君。

情景:

由于activiti与系统应用主题样式出入较大,协商后决定将activiti的editor-app放在前台。

ps:主要iframe解决多项目集成,重写httpRequest添加token,但都2020年了,其实优选微前端方案集成。

步骤:

  1. 将activiti放在public即静态目录下。
  2. 通过iframe在相应的前台工作流界面引入activiti的model.html(最外层的主html,名字可能有出入)。
  3. mounted时将this,即vuecompoennt对象赋值给iframe,这样可以在保存后进行页面切换,或者某个接口回调后控制vue界面的状态。
    mounted(){
        window.getMyVue = this;//全局存入当前vue实例,供activiti调用
    }
  4. 因为涉及到了权限问题,而通过iframe引入的页面本身不会跟我们系统的请求头一致,需要在页面主html文件加上下面一段代码。
    //model.html
    <script>
       (
        function(open){
        XMLHttpRequest.prototype.open = function(method,url,async,user,pass){
            open.call(this,method,url,async,user,pass);//this指XMLHttpRequest
            this.setRequestHeader("token",window.parent.getMyVue.token);//mounted时传入的token
        }
    	}
    	)(XMLHttpRequest.prototype.open)
    </script>

     

  5. 配置下url的config文件,通过network调试查看那个接口有问题,在activiti文件目录全局搜对应问题。
  6. 至此,已完成接入。

下面是自己做activiti集成时的代码,供参考:

//vue中引入activi代码

<template>
    <div class="full-screen">
        <div class="main-section flex-column">
            <iframe ref="activit" width="100%" height="100%" :src="src" style="border:none"></iframe>
        </div>
    </div>
</template>
<script>
  import Api from '@/config';//服务器地址配置
  import Vue from 'vue';
  import {getToken} from '@/utils/auth';//登陆人的token
  export default{
    computed:{
        src(){
         return Api.preUrl + "/modeler.html?modelId=" + this.$store.modelId;//activiti主html路径 
        },
        apiUrl(){
        retirm Api.apiUrl + "/api-hclp-activiti-server";//后台部署的api服务
        },
        token(){
        return getToken();//token
    }
   },
    methods:{
    goto(){
    this.$message.success("保存模型成功");
    this.$router.push({name:"/sys/activiti"})    
}    
},
    mounted(){
    window.getMyVue = this;//全局存入当前vue实例,供activiti调用    
}
}
</script>

//修改activiti中app-cfg改变调用地址

var ACTIVITI = ACTIVITI || {};
ACTIVITI.CONFIG = {
    contextRoot:(function(){
    return window.parent.getMyVue.apiUrl;//上一步将vue实例传入的父窗口
    })()
}

 

toolbar-default-actions.js  文件是工具栏的控制函数,可在此文件内部调用vue的生命周期来完成业务中例如保存成功后的业务逻辑(如跳转页面)

 

效果图:

效果图

开发途中遇到的问题:

1.请求与vue不共享,不带请求头,需要手动在文件里扩展XMLHttpRequest。

2.X/JSON报错,不影响开发。

3.有个{model}/json的接口获取编辑器配置内容,起初因后台缺少某个json格式的文件,导致无法展示界面。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132434.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月10日 下午8:00
下一篇 2022年6月10日 下午8:00


相关推荐

  • win7电脑卡顿严重解决方法_电脑卡顿一下

    win7电脑卡顿严重解决方法_电脑卡顿一下最近有很多游戏玩家和小编说win7电脑玩2D游戏经常发生卡顿,游戏卡顿问题确实让玩家苦恼,因为导致2D游戏经常发生卡顿的原因有很多种,那么win7电脑玩2D游戏经常发生卡顿怎么办?不要着急,针对此问题,下面小编告诉大家造成2D游戏经常发生卡顿的六大解决方法。解决方法一:1、建议下载并安装【百度电脑专家】,2、打开【百度电脑专家】,在搜索框内输入“玩游戏卡”,在搜索结果里面选择第一项的【立即修复】,…

    2025年10月27日
    4
  • OpenClaw 支持群晖 Chat 渠道进行对话:@openclaw/synology-chat 简易教程

    OpenClaw 支持群晖 Chat 渠道进行对话:@openclaw/synology-chat 简易教程

    2026年3月13日
    2
  • coze扣子插件教程

    coze扣子插件教程

    2026年3月12日
    2
  • 个人嵌入式学习总结

    个人嵌入式学习总结个人认为,嵌入式学习主要经过以下几个阶段,1. 嵌入式linux的移植;主要包括u-boot源码的修改,kernel针对特定硬件平台的修改,系统硬体驱动的移植,根文件系统的制作;2. 系统电路设计;包括根据系统功能选择硬件资源,接口电路的设计;PCB电路图的设计与布线优化。3. linux驱

    2022年5月15日
    44
  • igmp应用_udp协议端口怎么测试

    igmp应用_udp协议端口怎么测试实验3:1)准备两台机,装linux系统。两机设置好IP后均运行routeadd-net224.0.0.0netmask224.0.0.0deveth0添加到组播组2)运行make编译3)A机运行./server4)B机运行./client服务端server.c代码如下:/**broadcast_server.c-多播服务程序*/#include#include#include#include……

    2025年11月15日
    4
  • MATLAB拟合算法

    MATLAB拟合算法与插值问题不同 在拟合问题中不需要曲线一定经过给定的点 拟合问题的目标是寻求一个函数 曲线 使得该曲线在某种准则下与所有的数据点最为接近 即曲线拟合的最好 最小化损失函数 插值算法中 得到的多项式 f x 要经过所有样本点 但是如果样本点太多 那么这个多项式次数过高 会造成龙格现象 尽管我们可以选择分段的方法避免这种现象 但是更多时候我们更倾向于得到一个确定的曲线 尽管这条曲线不能经过每一个样本点 但只要保证误差足够小即可 这就是拟合的思想 拟合的结果是得到一个确定的曲线 先给出一组例子

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号