BPM不同表单之间子表的赋值
上次写的是同一个表单的子表之间赋值,这次是不同表单之间子表的赋值
首先,我们给需要赋值的表单添加一个复制按钮
$.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不同表单之间子表的赋值的更多相关文章
- layui父表单获取子表单的值完成修改操作
最近在做项目时,学着用layui开发后台管理系统. 但在做编辑表单时遇到了一个坑. 点击编辑时会出现一个弹窗. 我们需要从父表单传值给子表单.content是传值给子表单 layer.open({ t ...
- 表单的子元素可不在form标签内
表单是网页用于向服务器发送数据的元素.其用法类似下面: <form method="POST" action="/login"> <input ...
- HTML 5 服务器发送事件、Input 类型、表单元素、表单属性
HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新. Server-Sent 事件 - 单向消息传递 Server-Sent 事件指的是网页自动获取来自服务器 ...
- Html5学习进阶四 表单元素和表单属性
HTML5 的新的表单元素: HTML5 拥有若干涉及表单的元素和属性. 本章介绍以下新的表单元素: datalist keygen output 浏览器支持 Input type IE Firefo ...
- 工作流Activiti框架中表单的使用!详细解析内置表单和外置表单的渲染
Activiti中的表单 Activiti提供了一种方便而且灵活的方式在业务流程中以手工方式添加表单 对表单的支持有2种方式: 通过表单属性对内置表单进行渲染 通过表单属性对外置表单进行渲染 表单属性 ...
- 解决iphone填写表单时,表单项获取焦点时往下拉屏,导致顶部标题栏下滑错位
$(function () { //解决iphone填写表单时,表单项获取焦点时往下拉屏,导致顶部标题栏下滑错位 var u = navigator.userAgent; var isiOS = !! ...
- BootStrap 智能表单系列 九 表单图片上传的支持
本章介绍如何在生成表单后,可以支持上传图片后可以及时预览图片 代码如下(连接地址:https://github.com/xiexingen/Bootstrap-SmartForm/blob/maste ...
- BootStrap 智能表单系列 六 表单数据绑定(编辑页面的数据绑定)
本章介绍如何在生成表单后,将一个model的数据展示到form表单中(一般用于编辑页面) 代码如下(连接地址:https://github.com/xiexingen/Bootstrap-SmartF ...
- BootStrap 智能表单系列 五 表单依赖插件处理
这一章比较简单哦,主要就是生产表单元素后的一些后续处理操作,比如日期插件的渲染.一些autocomplete的处理等,在回调里面处理就可以了, demo: $("input.date-pic ...
随机推荐
- i合拍应用客户端安卓项目源码
i合拍是一款新型的拍照社交App它可以让你和朋友,亲人,陌生人合拍一张照片参与别人的合拍,体现自己的创意使用说明:使用了gpuimage进行滤镜渲染 实现远程合拍,分享合拍等一系列功能. 手机app下 ...
- EF CodeFirst 基础命令
PM> enable-migrations 已在项目"EasyWeChat.Data"中启用迁移.若要覆盖现有迁移配置,请使用 -Force 参数. PM> add-m ...
- redis客户端连接到服务器的步骤
和大多数客户端连接到服务器一样,redis-cli连接到服务器也主要分为两个阶段,请求连接阶段和数据传送阶段.具体来讲redis-cli做的事情有: 1.以socket方式建立连接: 2,选择相应的数 ...
- mysql主从机制的部署与应用
部署mysql主从复制 Mysql master ip: 192.168.30.25 一主两从 Mysql slave ip: 192.168.30.24 Mysql slave ip:192.1 ...
- lucene7.1.0实现搜索文件内容
Lucene的使用主要体现在两个步骤: 1 创建索引,通过IndexWriter对不同的文件进行索引的创建,并将其保存在索引相关文件存储的位置中. 2 通过索引查寻关键字相关文档. 首先,我们需要定义 ...
- USACO 4.1 Fence Rails
Fence RailsBurch, Kolstad, and Schrijvers Farmer John is trying to erect a fence around part of his ...
- EasyUI 解决Js动态加载页面样式不显示问题
var strHtml = "<input name='mydate' class='easyui-datebox'>"; 直接使用append把内容加载到页面中,Ea ...
- PHP AES cbc模式 pkcs7 128加密解密
今天在对接一个第三方接口的时候,对方需要AES CBC模式下的加密.这里简单写一个demo class Model_Junjingbao extends Model { private static ...
- Java基础之 HelloWorld
1. Java发展史 参考: https://www.cnblogs.com/guoqingyan/p/5667064.html 2. Java中 JDK, JRE, JVM之间的关系 参考: htt ...
- @Zookeeper可视化工具。 ZK 安装 node-zk-browser。2015.10.22亲测可用
zookeeper基本是基于API和console进行znode的操作,并没有一个比较方便的操作界面,这里也发现了taobao 伯岩写的一个工具,可以比较方便的查询zookeeper信息. 工具的开发 ...