返回列表 发布新帖

hooks怎么设置校验信息

1359 2
发表于 2025-4-18 16:59:40 | 查看全部 阅读模式
问答

紧急程度

已完结
给表格添加了一个hooks,在有数据变动时进行唯一性校验。如果不通过需要展示校验信息

参照例子写了一个但是serErrors一直报underfined。使用ai生成的脚本也报这个错。这个方法是被移除了吗?这个功能目前要怎么实现?
QQ截图20250418165728.png
图片1.png

最佳答案

查看完整内容

本帖最后由 翁俊 于 2025-4-24 10:34 编辑 1、首先你的错误是因为你没有找到单元格实例,导致的,设置错误方法是存在可以用的 2、其次你可以提个bug单给开发平台,目前提供的AI功能不准确,推荐的方法不对 3、下面可以看下我的代码以及实现效果,用于参考 // 获取当前组件实例的代理对象 const tableComponent = component.getTableComponent(); // 获取表格所有行数据 const allRows = tableComponent.getAllRowData(); // ...

评论2

翁俊Lv.7 发表于 2025-4-21 11:45:17 | 查看全部
排查验证中
翁俊Lv.7 发表于 2025-4-22 18:26:17 | 查看全部
本帖最后由 翁俊 于 2025-4-24 10:34 编辑

1、首先你的错误是因为你没有找到单元格实例,导致的,设置错误方法是存在可以用的

2、其次你可以提个bug单给开发平台,目前提供的AI功能不准确,推荐的方法不对
3、下面可以看下我的代码以及实现效果,用于参考
// 获取当前组件实例的代理对象
const tableComponent = component.getTableComponent();

// 获取表格所有行数据
const allRows = tableComponent.getAllRowData();

// 遍历所有行数据
allRows.forEach((row, rowIndex) => {
  // 获取当前行的所有单元格组件
  const rowData = row.value;
  const keys = Object.keys(rowData);

  // 遍历当前行的所有单元格
  keys.forEach((key) => {
    // 获取当前单元格的值
    const cellValue = rowData[key];
    // 检查其他行是否有相同的值
    const isDuplicate = allRows.some((otherRow, otherRowIndex) => {
      // 排除当前行
      if (rowIndex !== otherRowIndex) {
        return otherRow.value[key] === cellValue;
      }
      return false;
    });
    // 如果有重复值,设置错误信息
    if (isDuplicate) {
      // 获取当前单元格组件实例
      const cellComponent = tableComponent.getControlByPath(`exampltest.${rowIndex}.${key}`);
      // 设置错误信息
       cellComponent.setErrors([{
          key: 'customInvalid',
          type: 'error',
          errorMessage: '输入错误',
        }]),
      tableComponent.markForCheck();
      console.log('走到错误信息提示这')
    } else {
      // 清除错误信息
        const cellComponent = tableComponent.getControlByPath(`exampltest.${rowIndex}.${key}`);
        component.setErrors([);
    }
    tableComponent.markForCheck();
  });
});

最终实现效果

                               
登录/注册后可看大图

大家来答
    精选文章
    DAP后端应用写法-使用DWDataSet进行数据库的新增/修改
    场景使用高代码后端要去数据库变更数据, 除了直接下SQL的方式外, 更可用java物件的方
    DAP后端应用写法-使用DWQueryInfo进行数据库的查询
    场景使用高代码后端要去数据库查资料, 除了直接下SQL的方式外, 更可用java物件的方式,
    排錯技巧 - 雅典娜签核,间歇性会报错
     问题描述顾问反馈:雅典娜签核套件点击OA送签或查看签核流程时,间歇性会报错。
    鼎捷雅典娜-运营单元
     背景说明鼎捷雅典娜是云地整合的架构,在新客户期初导入时,需要针对新客户租户
    排错技巧 - 地中台无法启用
    问题描述顾问反馈:客户在完成新版更新后,服务无法正常启用! 错误信息如下,地中台
    • 关注公众号
    Copyright © 2025 鼎捷数智股份有限公司 版权所有 All Rights Reserved. Powered by Discuz! X5.0
    关灯 在本版发帖
    即将开放
    返回顶部
    快速回复 返回顶部 返回列表