开发者社区> 问答> 正文

宜搭 在子表单中 怎么通过js动态实现新添加一行

宜搭 在子表单中 怎么通过js动态实现新添加一行

展开
收起
游客tr5n6p6ioj5ks 2023-04-27 14:06:08 1755 1
来自:钉钉宜搭
3 条回答
写回答
取消 提交回答
  • 在宜搭中,可以通过 JavaScript 脚本来动态实现新添加一行子表单数据的操作。具体实现方式如下:

    1. 在您需要添加子表单的按钮或事件中,添加 JavaScript 脚本代码。

    2. 在脚本中,通过 API 获取当前子表单的数据,然后在数据中添加一行新的空数据行,最后将新的数据行保存到子表单中。

    例如,在 JavaScript 脚本中,您可以使用以下代码来实现新添加一行子表单数据的操作:

    // 获取子表单控件名
    const subform = 'your-subform-name';
    
    // 获取当前子表单的数据
    const formData = data.get(subform);
    
    // 添加一个新的空数据行
    const newRow = {};
    const columns = data.getColumns(subform);
    columns.forEach(column => {
      newRow[column.columnName] = '';
    });
    
    // 在数据中添加新的行
    formData.push(newRow);
    
    // 将新的子表单数据保存到数据源
    data.set(subform, formData);
    

    这样,当您点击按钮或触发事件时,就会动态添加一行新的空数据行到子表单中,并保存到数据源中,供后续操作使用。

    需要注意的是,为了能够在 JavaScript 脚本中操作子表单数据,您需要在流程设计器中配置相应的子表单控件和数据源,并且设置好相关的权限控制规则

    2023-04-30 23:38:51
    赞同 1 展开评论 打赏
  • 这是返回的数据 image.png

    image.png 上面的图片为初次加载时 子表单只有一行 且值为空,先要求根据接口返回的数据长度来决定添加几行,并且将值赋值给每行,即下面图片的形式 image.png 官方使用手册是真的一言难尽啊!! 也可能是我太拉!! 完整代码如下

          if (info && info.length > 0) {
            let newValue = info.map((item) => {
              console.log("key值", Object.keys(item)[0])
              console.log("value值", Object.values(item))
            
              return {
                "var info = response.data[0].formData.tableField_lgvth8zq
          if (info && info.length > 0) {
            let newValue = info.map((item) => {
              console.log("key值", Object.keys(item)[0])
              console.log("value值", Object.values(item))
            
              return {
                "textField_lgvth8zv": Object.values(item)[0],//textField_lgvth8zv 子表单 第一个元素的唯一标识
                "textField_lgvth8zw": Object.values(item)[1],//textField_lgvth8zw子表单 第二个元素的唯一标识
              }
            })
            this.$("tableField_lgvth8zq").setValue(newValue);//tableField_lgvth8zq 子表单组件唯一标识  注意区别
          } else {
            this.$("tableField_lgvth8zq").reset();
          }
        });": Object.values(item)[0], //
                "textField_lgvth8zw": Object.values(item)[1],
              }
            })
            this.$("tableField_lgvth8zq").setValue(newValue);
          } else {
            this.$("tableField_lgvth8zq").reset();
          }
    
        
        });
    
    2023-04-28 10:01:45
    赞同 1 展开评论 打赏
  • 十年摸盘键,代码未曾试。 今日码示君,谁有上云事。

    某些特定的场景下,子表单内的序号不能直接使用,我们想要将子表单的序号填入到子表单内的组件后在其他的地方使用,比如业务关联规则或者是公式等,可以参考以下案例。

    子表单序号生成函数

    // 生成子表单序号 // tableFieldId:子表单组件唯一标识 // orderFieldId:序号字段唯一标识 // beforeText:序号前缀文案 // afterText:序号后缀文案 export function setOrderNum(tableFieldId, orderFieldId, beforeText = '', afterText = '') {   if (!tableFieldId || !orderFieldId) { return };   const tableField = this.$(tableFieldId);   const items = tableField.getItems();   items.forEach((item, index) => {     const updateObject = {};     updateObject[orderFieldId] = '${beforeText}${index + 1}${afterText}';     tableField.updateItemValue(item, updateObject);   }); }

    表单 onChange 时调用该函数 已在子表单 onChange 中处理新增一项逻辑。

    页面初始化 didMount 时调用该函数

    实现效果

    2023-04-27 18:25:44
    赞同 2 展开评论 打赏
问答分类:
问答地址:
关联地址:
相关产品:
来源圈子
更多
收录在圈子:
+ 订阅
「宜搭」是云钉原生低代码平台(钉钉 PaaS - aPaaS),让企业应用搭建更简单! 帮助中小企业降本提效,加强组织的数字化自主权; 帮助大型企业释放个体创新力,助力组织创新涌现。
相关文档: 宜搭
问答排行榜
最热
最新

相关电子书

更多
宜搭 - 企业智能化应用搭建平台 立即下载
《云市场-宜搭解决方案》 立即下载
《宜搭开发手册》 立即下载