微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

不允许重复值的字段数组验证

如何解决不允许重复值的字段数组验证

我已经使用 redux 形式实现了一个字段数组组件。在我的字段数组中,我对输入中不包含例如字母进行了一些验证。我的验证功能是这样的:

const validateFieldArray = (values) => {
  const errors = {
    [LEGO_AMKA_ARRAY]: []
  };
  if (values.get(LEGO_AMKA_ARRAY)) {
    const amkas = values.get(LEGO_AMKA_ARRAY);
    amkas.forEach((field,index) => {
      const amkasErrors = {};
      const amkaField = field.get(AMKA_FIELD);
      if (!amkaField) {
        amkasErrors[AMKA_FIELD] = 'error.required';
        errors[LEGO_AMKA_ARRAY][index] = amkasErrors;
      } else if (onlyNumeric(amkaField) !== undefined) {
        amkasErrors[AMKA_FIELD] = 'error.numbers.allowed';
        errors[LEGO_AMKA_ARRAY][index] = amkasErrors;
      }
    });
  }
  return errors;
};

我想添加一个不允许重复条目的验证。如果我输入一个在前一个字段中输入的值,我一定不允许这样做。我该怎么做?

谢谢!

解决方法

您可以使用reduce创建每个值及其在值数组中出现的字典(注意-您可能需要在reduce之前使用map,我不确定您的数组结构如何)

const dictOccurrences = values.get(LEGO_AMKA_ARRAY).reduce((acc,curr) => ({
    ...acc,[curr]: acc[curr] ? acc[curr] + 1 : 1,}),{});

然后在您的代码中:

const validateFieldArray = (values) => {
  const errors = {
    [LEGO_AMKA_ARRAY]: []
  };
  if (values.get(LEGO_AMKA_ARRAY)) {
    const amkas = values.get(LEGO_AMKA_ARRAY);
    const dictOccurrences = amkas.reduce((acc,{});
    amkas.forEach((field,index) => {
      const amkasErrors = {};
      const amkaField = field.get(AMKA_FIELD);
      if (!amkaField) {
        amkasErrors[AMKA_FIELD] = 'error.required';
        errors[LEGO_AMKA_ARRAY][index] = amkasErrors;
      } else if (onlyNumeric(amkaField) !== undefined) {
        amkasErrors[AMKA_FIELD] = 'error.numbers.allowed';
      }
      if (dictOccurrences[amkaField] > 1) {
        amkasErrors[AMKA_FIELD] = 'error.duplicate';
      }
      errors[LEGO_AMKA_ARRAY][index] = amkasErrors;
    });
  }
  return errors;
};

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。