手册
1. 表单扩展
1.1 表单设计时如何添加JS校验
1.2 【引入脚本】实现修改人与修改日期在编辑时更新
1.3 【引入脚本】字段值为空时不显示
1.4 表单列表数据导入jar包校验说明
1.5 通过表单js控制子表的显示或隐藏
1.6 主表汇总获取子表的描述信息
1.7 【初始赋值】如何对某个字段赋初始默认值
1.8 数字字段对比不允许大于另一个字段
1.9 【引入脚本】多选框的隐藏显示控制
1.10 PC表单隐藏控件内容
1.11 【引入脚本】通过表单参数判断来实现接口参数回填
1.12 【按钮前置事件】通过按钮事件来校验表单账号是否有邮箱
1.13 【引入脚本】通过调用本地关联查询的接口将第一行数据回填至表单
1.14 【编写公式】日期格式化
1.15 【子表回填】子表对话框数据根据主表选择的内容自动回填
1.16 【引入脚本】js调用接口执行一个脚本,获取数据后反填到表单上或者将结果与表单内容对比,可以做表单校验
1.17 【引入脚本】js将子表末行的数据更新
1.18 【引入脚本】控制子表回填按钮的隐藏
1.19 【引入脚本】通过表单参数判断来实现子表的只读和编辑效果
1.20 【引入脚本】隐藏子表的添加按钮
1.21 【引入脚本】隐藏子表每行复制、删除等按钮
1.22 【关联查询】自定义SQL过滤数据
1.23 【引入脚本】实现流程第二节点回传数据致表单
1.24 【引入脚本】js控制子表中单独一行的某个字段的显示隐藏
1.25 【引入脚本】js请求接口,获取数据后将数据push到子表上
1.26 通过字段控制其他字段的显隐读写
2. 门户扩展
3. 流程定义扩展
3.1 分支网关的变量如何获取子表数据
3.2 通过初始赋值获取多人会签节点的审批人并存储到某一字段
3.3 通过按钮控制工单状态
3.4 流程分支网关处用发起人所属角色判断走向
4. 人员脚本扩展
5. 常用脚本扩展
5.1 流程状态通知方案
5.2 节点按钮前置脚本
5.3 更新字段值
6. 表单列表扩展
6.1 如何格式化内容导出
6.2 如何格式化复选选项
6.3 【JS按钮】表单列表审批人通过js按钮跳转至对应的待办
6.4 【JS按钮】通过JS按钮点击发起流程,并将当前行某字段数据自动推送到发起流程的表单中
6.5 【数据过滤】表单列表中数据根据当前人过滤当前人审批过的数据
6.6 【js扩展】根据日期比较结果控制字段颜色
6.7 【前置js脚本】控制按钮显隐
7. 功能高级说明
7.1 流程按钮_加签/征询/流转
7.2 对话框/关联查询自定义SQL的使用
8. 典型场景应用
8.1 填报汇总功能
8.2 考勤审批管理
8.3 表单校验
8.4 绑定查询关联操作说明
8.5 快速批量添加数据,引入脚本
8.6 通过sql和数据列表的方式快速生成考勤统计报表
8.7 栏目中配置跳转地址

【引入脚本】实现修改人与修改日期在编辑时更新

2321
鲁聪
2021-01-18 13:51:59
分享链接
摘要:修改人,修改日期功能如何实现,js获取常用脚本

场景:我们使用表单创建功能模块时,通常需要固定的几个字段:创建人,创建时间,修改人,修改时间。

创建人和创建时间可以通过表单的 获取当前用户 与 获取当前时间 功能实现,那么修改人和修改时间是需要每次编辑的时候重新获取的,该如何实现呢?

其中,修改时间是客户端的时间,还是服务端的时间?


实现方案如下:

1.建模时创建 修改人 与 修改日期两个字段

2.表单引入脚本中写一下JS脚本实现,其中“ xtmrzd”为BO名称,“ xgr ”为:修改人,“ xgsj ”为修改日期

若是要获取用户账号,可以将 currentUser.username 改为  currentUser.account;

修改时间获取 客户端时间 写法:

function getCurrentDate(){
    let date = new Date();
    let month = (getFormaryVal(date.getMonth() + 1)); 
    let day = getFormaryVal(date.getDate())
    let hours = getFormaryVal(date.getHours());
    let minutes = getFormaryVal(date.getMinutes());
    let seconds = getFormaryVal(date.getSeconds());
    return `${date.getFullYear()}-${month}-${day} ${hours}:${minutes}:${seconds}`;
    
}
function getFormaryVal(str){
    if(!str){
        return "";
    }
    if(typeof str == "number"){
        str = "" + str;
    }
    if(str.length == 1){
        str = "0" + str;
    }
    return str;
}
let boEnt = document.querySelector("[name='online-form']").__vue__.data.xtmrzd;
setTimeout(()=>{
boEnt.xgr = window.app.$store.state.login.currentUser.username;
},10)
boEnt.xgsj = getCurrentDate();


修改时间获取 服务端时间 写法:

let boEnt = document.querySelector("[name='online-form']").__vue__.data.xtmrzd;
window.app.$http.post(
    `${window.context.bpmRunTime}/runtime/script/v1/executeScript`,
    "return scriptImpl.getCurrentDateByStyle('yyyy-MM-dd HH:mm:ss');"
    ).then(resp=>{
        boEnt.xgsj = resp.data.value;
    })
setTimeout(()=>{
    boEnt.xgr = window.app.$store.state.login.currentUser.username;
},10)





发表评论
评论通过审核后显示。