手册
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 栏目中配置跳转地址

快速批量添加数据,引入脚本

803
唐乐
2021-09-03 14:42:58
分享链接

一、通过表单引入js,实现根据主表数据信息,实现子表数据自动批量添加;

场景:适用批量维护楼盘等,批量数据维护快速批量生成的方式,实现数据快速添加。

二、实现详情方式:

1. 以房屋维护表为例,根据规则字段字段生成对应的子表数据;


2. 2.首先需建五个表。分别为座栋表、单元表、楼层表、房屋表、和一张建它们关联起来的房屋批量生成表。

座栋表:

单元表:

 

楼层表:

 

房屋表:

 

批量生成表,用于将这四张表以外部表的形式关联起来:

添加外部表操作信息可参考链接:

http://www.hotent.org:8880/chanzhi/index.php/book/design-center/31.html

 

3、新建表单。

将这五个建模的表,新建五个表单,根据表单的样式喜好可以自定义;

 

这里以批量添加表为例;


 

子表是根据主表字段自动生成的,所以需要将子表拖到表单内,将子表字段拉出来。

子表分别对应四个外部表。座栋表、单元表、楼层表、房屋表,将对应的字段拉到表单内。

 


表单设计可参考链接:http://www.hotent.org:8880/chanzhi/index.php/book/EIPSAAS7.2/34.html

4、编写对应的规则脚本;

这里规则:

座栋数、单元数、楼层数、房间数皆为整数

交互逻辑:

根据填写的内容自动生成座栋、单元、楼层和房间,如填写的座栋数为2、单元数为2、楼层数为2、房间数为2,起始编号为1,则需要新建两个座栋,座栋名为1和2,每栋两个单元1单元、2单元,每单元两层,每层两个房间

在表单左上角点击引入脚本,然后编写对应js脚本代码:


 

 

Js脚本如下:

const vm = document.getElementsByName("online-form")[0].__vue__;
let { pqplscfw } = vm.data;
//需要触发监听的字段
let fields = ["zds", "qsbh", "lcs", "fjs", "dys", "zddw", "lcdw", "fjdw"];
vm.$nextTick(() => {
  fields.forEach((field) => {
    vm.$el
      .querySelector(`[model-name='data.pqplscfw.${field}']`)
      .__vue__.$children[0].$on("blur", () => {
        validateFields();
      });
  });
});

function validateFields() {
  //如果能校验通过
  vm.$root.$validator.validateAll("custom-form").then((result) => {
    if (result) {
      if (Number(pqplscfw.zds) < Number(pqplscfw.qsbh)) {
        vm.$message.warning("座栋数不能小于起始编号");
        pqplscfw.zds = "";
        pqplscfw.qsbh = "";
        return;
      }
      doNext();
    }
  });
}

function doNext() {
  let subFields = ["sub_fwplb", "sub_dyplb", "sub_zdplb", "sub_lcplb"]; //子表名
  subFields.forEach((item) => {
    //清空子表数据
    pqplscfw[item].splice(0);
  });
  let { zds, qsbh, lcs, fjs, dys, zddw, lcdw, fjdw } = pqplscfw;
  zds = Number(zds);
  qsbh = Number(qsbh);
  lcs = Number(lcs);
  fjs = Number(fjs);
  dys = Number(dys);
  for (let build = qsbh; build <= zds; build++) {
    let buildingName = `座栋-${build}`;
    //添加坐栋表
    handleAddSubTableWithValues("sub_zdplb", {
      F_zddw: zddw,
      F_zdmc: buildingName,
    });
    //处理单元
    for (let unit = 1; unit <= dys; unit++) {
      let unitName = `单元-${unit}`;
      //添加单元表
      handleAddSubTableWithValues("sub_dyplb", {
        F_zdmc: buildingName,
        F_dymc: unitName,
      });
      //处理楼层
      for (let floor = 1; floor <= lcs; floor++) {
        let floorName = `楼层-${floor}`;
        //添加楼层表
        handleAddSubTableWithValues("sub_lcplb", {
          F_lcdw: lcdw,
          F_zdmc: buildingName,
          F_dymc: unitName,
          F_wllc: floorName,
        });
        //处理房间
        for (let room = 1; room <= fjs; room++) {
          let roomName = `房间-${room}`;
          //添加房间表
          handleAddSubTableWithValues("sub_fwplb", {
            F_zdmc: buildingName,
            F_dymc: unitName,
            F_lcmc: floorName,
            F_fzbh: roomName,
            F_fjdw: fjdw,
          });
        }
      }
    }
  }
}

function handleAddSubTableWithValues(subTabField, map) {
  let subInitData = pqplscfw["initData"][subTabField.replace("sub_", "")] || {};
  let str = JSON.stringify(subInitData).replace(/null/g, '""');
  let subData = JSON.parse(str);
  subData["sub_guid"] = uid();
  for (let key in map) {
    subData[key] = map[key];
  }
  pqplscfw[subTabField].push(subData);
}

function uid() {
  return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) {
    var r = (Math.random() * 16) | 0,
      v = c == "x" ? r : (r & 0x3) | 0x8;
    return v.toString(16);
  });
}

效果图:


可下载导入表单:



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