我想验证对象数组的有效时间值

时间:2020-09-25 20:27:06

标签: javascript validation yup

我正在尝试验证以下对象数组: [{from: '10:00', to: '16:00'}, null, {from: '09:00', to: '16:00'}, etc. ]

我要在该数组中恰好有7个对象,如何验证呢?我想同时添加.min(7).max(7)并不是最佳实践。我该如何也让NULL值通过?

这另一部分也很好,还是您会更改某些内容?我是JavaScript的新手。

schedule: array().of(
    object().shape({
      from: string()
        .required()
        .matches(/^(0[0-9]|1[0-9]|2[0-3]):(00|30)$/),
      to: string()
        .required()
        .matches(/^(0[0-9]|1[0-9]|2[0-3]):(00|30)$/),
    })
  ),

2 个答案:

答案 0 :(得分:1)

要检查简单时间值即12:34,可以使用以下正则表达式:/^[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$/。代码:

var item = '10:00';
console.log(item.match(/^[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$/));

  • ^:指示字符串的开头。
  • [0-5]:从0到5的一些字符。
  • [0-5]{1}:一些0到5的字符,也正是其中之一。
  • [0-9]:介于0到9之间的某个字符。
  • [0-9]{1}:介于0到9之间的某个字符,并且恰好是其中之一。
  • [0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}:介于00:00和59:59之间。
  • $:指示字符串的结尾。

我已经为您的数据结构实现了它。注意:我添加了一个错误的值,因此我们可以看到它实际上表明无效。

var items = [
  {from: '10:00', to: '16:00'},
  null,
  {from: '09:00', to: '16:00'},
  {from: '09:00', to: '16:001234'}
];

items.forEach((item) => {
    logstring = "Item : ";
    if(!item) {
      logstring += 'NULL/VALID';
    } else {
      logstring += item.from + " " ;
      if(item.from.match(/^[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$/)) {
          logstring += 'VALID';
      } else {
          logstring += 'INVALID';
      }
      
      logstring += ', ' + item.to + " " ;
      if(item.to.match(/^[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$/)) {
          logstring += 'VALID';
      } else {
          logstring += 'INVALID';
      }
    }
    console.log(logstring);
});

答案 1 :(得分:0)

使用验证is()属性。这是文档链接:https://validatejs.org/#validators-length