使用Parsley验证多个字段?

时间:2014-12-09 15:56:25

标签: javascript validation parsley.js

我有三个用于输入日期的文本输入字段。我想验证这些,以确保它们一起是一个有效的日期。我可以编写JavaScript来测试某些日期,但是我无法一次性使用Parsley.js验证多个字段,并提供单个错误消息。

我的字段是这样的:

<input type="number" name="date-day" value="" maxlength="2">
<input type="number" name="date-month" value="" maxlength="2">
<input type="number" name="date-year" value="" maxlength="4">

来自this answer我怀疑答案是这不是(简单)可能,但这似乎是一个非常普遍的需要,所以我想100%肯定!

1 个答案:

答案 0 :(得分:4)

这里大概是我最终得到的结果。这是我的HTML现在:

<input type="number" name="dob-day" value="" maxlength="2" class="js-dob-day" required="required" data-parsley-date="js-dob">
<input type="number" name="dob-month" value="" maxlength="2" class="js-dob-month">
<input type="number" name="dob-year" value="" maxlength="4" class="js-dob-year">

我为每个字段添加了一个唯一的类,因此我可以获得它们的值。并在日输入中添加了requireddata-parsley-date

这是我的JavaScript添加验证程序,该验证程序检查组合字段以查看它们是否生成有效日期。为了完整性,我在验证器中使用了两个实用程序函数。验证器依赖moment.js检查最终字符串的有效性。

// Is `n` a number or numeric string (eg "3")?
function isNumeric(n) {
    return !isNaN(parseFloat(n)) && isFinite(n);
};

// Pad `n` with `z` (or `0` by default) to `width`.
function zeroPad(n, width, z) {
    z = z || '0';
    n = n + '';
    return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
};


window.ParsleyValidator
    .addValidator(
        // Name of our validator.
        'date',

        // `value` will be the value entered into the day field.
        // `requirements` will be "js-dob" in our example.
        function(value, requirements) {
            var day     = $('.'+requirements+'-day').val(), // or value
                month   = $('.'+requirements+'-month').val(),
                year    = $('.'+requirements+'-year').val();

            if (isNumeric(day) === false
                || isNumeric(month) === false
                || isNumeric(year) === false) {
                return false;
            };

            day     = zeroPad(day, 2);
            month   = zeroPad(month, 2);
            year    = zeroPad(year, 4);

            // Use moment.js to make a date which we can then test for validity.
            var date = moment(year+'-'+month+'-'+day, 'YYYY-MM-DD');

            if (date.isValid()) {
                return true;
            } else {
                return false;
            };
        },

        // priority. Not sure how this works.
        34
    )
    .addMessage('en', 'date', "Enter a valid date");

任何建议都非常欢迎!