上次写的是同一个表单的子表之间赋值,这次是不同表单之间子表的赋值

首先,我们给需要赋值的表单添加一个复制按钮

$.MvcSheet.AddAction({
            Action: "start",
            Icon: "fa-copy",       // 按钮图标
            Text: "复制",           // 按钮名称
            OnActionDone: function (e) {
                window.open("../../../StartInstance.aspx?WorkflowCode=" + $.MvcSheetUI.SheetInfo.WorkflowCode + "&PageAction=Close&objectid=" + $.MvcSheetUI.SheetInfo.BizObjectID);
            },
            PostSheetInfo: false         // 是否提交表单数据,如果 false,那么不返回表单的数据
        });

WorkflowCode是流程编码,也就是说StartInstance需要知道你的流程编码来创建哪个流程因为我的就是重新创建一个本流程,只不过是不同表单之间的所以直接$.MvcSheetUI.SheetInfo.WorkflowCode获取。BizObjectID是数据模型id

然后根据实际需求,在应该开放的节点加上前端调用后端代码

//从前端调用后台方法
                $.MvcSheet.Action({
                    Async: false,
                    Action: "GetWorkplan",   // 后台方法名称
                    Datas: [],//传入参数,用逗号分开,这是是例子,这个方法是没有输入参数的
                    LoadControlValue: true, // 是否获取表单数据
                    PostSheetInfo: false,    // 是否获取已经改变的表单数据
                    OnActionDone: function (e) {
                        //这里e是后台返回的值,这里是一个类,如果是多行可以返回List<类>,下面用循环就行了
                        if (e && $.MvcSheetUI.SheetInfo.IsOriginateMode) {
                            var j = 1;
                            for (i in e) {
                                $("a[id^='Add_workplanitem']").click();
                                //这里我直接给第一行赋值,如果是多行,可以循环
                                //SetControlValue:第一个参数为数据项;第二个参数为需要赋的值;第三个参数为行号
                                $.MvcSheetUI.SetControlValue("workplanitem.zzxm", e[i]["Zzxm"], j);
                                $.MvcSheetUI.SetControlValue("workplanitem.SLBZ", e[i]["Slbz"], j);
                                $.MvcSheetUI.SetControlValue("workplanitem.SHLBZ", e[i]["Shlbz"], j);
                                $.MvcSheetUI.SetControlValue("workplanitem.ZLBZ", e[i]["Zlbz"], j);
                                j++;
                            }
                        }
                    }
                });

//IsOriginateMode的左右是判断当前是不是第一次填写表单

$("a[id^='Add_workplanitem']").click();的理解可以参考下边

$("input[id^='code']");//id属性以code开始的所有input标签

$("input[id$='code']");//id属性以code结束的所有input标签

$("input[id*='code']");//id属性包含code的所有input标签

至此,前台代码已经完毕

后台代码:

先创建一个workplan类,把你需要返回的值放到里边

public List<workplan> GetWorkplan()
        {
            List<workplan> workplanlist = new List<workplan>();
            string objectid = Request.QueryString["objectid"];
            if (!string.IsNullOrWhiteSpace(stryobjectid))
            {
                string strsql = "select * from i_workplanitem where ParentObjectID='{0}' order by parentindex";
                DataTable dt = OThinker.H3.WorkSheet.AppUtility.Engine.EngineConfig.CommandFactory.CreateCommand().ExecuteDataTable(string.Format(strsql, objectid));
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    workplan newworkplan = new workplan();
                    newworkplan.Zzxm = dt.Rows[i]["zzxm"] != null ? dt.Rows[i]["zzxm"].ToString() : "";
                    newworkplan.Slbz = dt.Rows[i]["slbz"] != null ? dt.Rows[i]["slbz"].ToString() : "";
                    newworkplan.Shlbz = dt.Rows[i]["shlbz"] != null ? dt.Rows[i]["shlbz"].ToString() : "";
                    newworkplan.Zlbz = dt.Rows[i]["zlbz"] != null ? dt.Rows[i]["zlbz"].ToString() : "";
                    workplanlist.Add(newworkplan);
                }
            }
            return workplanlist;
        }

BPM不同表单之间子表的赋值的更多相关文章

  1. layui父表单获取子表单的值完成修改操作

    最近在做项目时,学着用layui开发后台管理系统. 但在做编辑表单时遇到了一个坑. 点击编辑时会出现一个弹窗. 我们需要从父表单传值给子表单.content是传值给子表单 layer.open({ t ...

  2. 表单的子元素可不在form标签内

    表单是网页用于向服务器发送数据的元素.其用法类似下面: <form method="POST" action="/login"> <input ...

  3. HTML 5 服务器发送事件、Input 类型、表单元素、表单属性

    HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新. Server-Sent 事件 - 单向消息传递 Server-Sent 事件指的是网页自动获取来自服务器 ...

  4. Html5学习进阶四 表单元素和表单属性

    HTML5 的新的表单元素: HTML5 拥有若干涉及表单的元素和属性. 本章介绍以下新的表单元素: datalist keygen output 浏览器支持 Input type IE Firefo ...

  5. 工作流Activiti框架中表单的使用!详细解析内置表单和外置表单的渲染

    Activiti中的表单 Activiti提供了一种方便而且灵活的方式在业务流程中以手工方式添加表单 对表单的支持有2种方式: 通过表单属性对内置表单进行渲染 通过表单属性对外置表单进行渲染 表单属性 ...

  6. 解决iphone填写表单时,表单项获取焦点时往下拉屏,导致顶部标题栏下滑错位

    $(function () { //解决iphone填写表单时,表单项获取焦点时往下拉屏,导致顶部标题栏下滑错位 var u = navigator.userAgent; var isiOS = !! ...

  7. BootStrap 智能表单系列 九 表单图片上传的支持

    本章介绍如何在生成表单后,可以支持上传图片后可以及时预览图片 代码如下(连接地址:https://github.com/xiexingen/Bootstrap-SmartForm/blob/maste ...

  8. BootStrap 智能表单系列 六 表单数据绑定(编辑页面的数据绑定)

    本章介绍如何在生成表单后,将一个model的数据展示到form表单中(一般用于编辑页面) 代码如下(连接地址:https://github.com/xiexingen/Bootstrap-SmartF ...

  9. BootStrap 智能表单系列 五 表单依赖插件处理

    这一章比较简单哦,主要就是生产表单元素后的一些后续处理操作,比如日期插件的渲染.一些autocomplete的处理等,在回调里面处理就可以了, demo: $("input.date-pic ...

随机推荐

  1. 【PostgreSQL-9.6.3】表继承

    表继承是PostgreSQL特有的,子表可以从父表中继承字段和一些属性.例如: --创建一张表“persons”作为父表: test=# create table persons ( test(# i ...

  2. 菜鸟使用 centOS 安装 redis 并放入service 启动 记录

    1.下载redis: wget http://download.redis.io/releases/redis-2.8.17.tar.gz 若wget 不可用,请先安装wget yum install ...

  3. Linux之tar.gz file

    A tarball (tar.gz file) is compressed tar archive. The tar program provides the ability to create ta ...

  4. EnforceLearning-被动强化学习

    前言: 画图挺好:深度学习进阶之路-从迁移学习到强化学习 专家系统给出了知识节点和规则,使用粒度描述准确性,依靠分解粒度解决矛盾,并反馈知识和推理规则更新.专家系统与机器学习有本质区别,但从机器学习的 ...

  5. Linux 之secureCRT连接SSH

    1.登陆linux系统,打开终端命令.输入 rpm -qa |grep ssh 查找当前系统是否已经安装. 2.如果没有安装SSH软件包,可以通过yum  或rpm安装包进行安装. .3.安装好了之后 ...

  6. 小程序viewflex布局的对齐不对的问题

    index.wxml: <view class="container"> <view class="nav-container"> &l ...

  7. Java中StringTokenizer类的使用

    StringTokenizer是一个用来分隔String的应用类,相当于VB的split函数. 1.构造函数 public StringTokenizer(String str) public Str ...

  8. PAT_A1126#Eulerian Path

    Source: PAT A1126 Eulerian Path (25 分) Description: In graph theory, an Eulerian path is a path in a ...

  9. 启动模拟器的qq

    #coding = utf-8from appium import webdriver '''1.手机类型2.版本3.手机的唯一标识 deviceName4.app 包名appPackage5.app ...

  10. 【剑指Offer】55、链表中环的入口结点

      题目描述:   给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null.   解题思路:   本题是一个比较典型的链表题目,难度适中.首先,对于大多人来说,看到这道题是比较开心的 ...