Vee验证自定义跨域规则,比较两个时间字符串

时间:2019-06-11 19:37:45

标签: javascript vue.js vee-validate

我有两个时间序列,以我想要的形式验证,我想根据第一个验证第二个,只输入不超过一个小时的时差。我的字段粒度为毫秒。

我的脚本

import { Validator } from 'vee-validate';

//Cross-field Rules
Validator.extend('isOneHour', (value, [otherValue]) => {
  function toSeconds(time_str) {
    // Extract hours, minutes and seconds
    var parts = time_str.split(':');
    var mili = time_str.split('.')
    // compute  and return total seconds
    return parts[0] * 3600 + // an hour has 3600 seconds
      parts[1] * 60 +   // a minute has 60 seconds
      +parts[2]        // seconds
      + mili[0] / 1000;        //miliseconds

  }
  console.log(value, otherValue); // out
  var difference = Math.abs(toSeconds(value) - toSeconds(otherValue));


  return difference <= 3600;
}, {
    hasTarget: true
  });

我的模板:

<b-input
            @keyup.native.enter="getData()"
            editable
            :value="startTime"
            @change.native="startTime = $event.target.value"
            placeholder="ex. 11:22:00.000"
            icon="clock"
            v-mask="'##:##:##.###'"
            name="startTime"
            ref="endTime"
          ></b-input>
<b-input
            editable
            name="endTime"
            :value="endTime"
            @change.native="endTime = $event.target.value"
            placeholder="ex. 11:25:30.450"
            icon="stopwatch"
            @keyup.native.enter="getData()"
            v-mask="'##:##:##.###'"
            v-validate="'isOneHour:endTime'"
          ></b-input>

此代码不起作用,它将创建一个无限循环,这将导致应用程序崩溃。它适用于: var difference = Math.abs(toSeconds(value) - toSeconds(otherValue));

我的控制台错误是:TypeError: time_str.split is not a function

我在做什么错了?

1 个答案:

答案 0 :(得分:0)

所以!问题是我在Vee Validate上的事件设置为“”,而在将其设置为"blur"之后,触发了验证。 虽然错误来自error.first('symbol_input),但根据我的errorBagName来说,应该是vErrors.first('symbol_input')。 如果有人像我这样陷入困境,也许这个答案就是他们出问题的地方。