jquery Datepicker日期范围验证

时间:2012-03-30 08:55:52

标签: javascript jquery datepicker

我有一个像Born date这样的领域。我使用jquery datepicker来显示日历,以便用户可以选择日期。现在我遇到了问题。

在Born date字段中,有一个选项可以选择打开两个日期选择器字段,如

出生日期 - 介于--------- ---来自-------和--To ----------

现在的问题是,如果用户在“收件人”字段中选择的日期小于“来自字段”,请按提交按钮进行提交。我需要阻止它提交并显示相应的消息,以便用户输入正确的日期。

请帮助。

以下是我正在使用的代码

<input id="borndate"  class="dateISO" onchange="checkDate('borndate');">
</input>

<span id="span_borndate" style="display:none">
<input  id="borndate"  class="dateISO"  onchange="checkDate('borndate');">
</span>

这是我正在使用的Java脚本

function checkdate(fieldname) {

    var comparator = '#comp_' + fieldName;
    var compVal = $(comparator).val();
    Value = $('#' + fieldName).val();
    var fromDate = jQuery.datepicker.parseDate('mm-dd-yy', Value, null);
    Values = $('#' + fieldName + '-to').val();
    var toDate = jQuery.datepicker.parseDate('mm-dd-yy', Values, null);
    $('#span_' + fieldName).find('.error').remove();
    if (compVal == "Between") {
        if (toDate < fromDate) {
            $('#span_' + fieldName).append("<label class='rangeError' generated='false'>Start date should come before end date</label>");
            return false;
        }
    }
    return true;
}

这是在提交

时再次调用的函数
function validateforms() {
    var valid = true;
    $('//classnamefor table rows which includes the date td').each(function (index) {
        fieldName = $(this).attr("name");
        if ($('#' + fieldName).hasClass('dateISO')) {
            valid = checkDate(fieldName);
        }
    }
    return valid;
}

1 个答案:

答案 0 :(得分:1)

试试这个

http://jqueryui.com/demos/datepicker/#date-range

并使文本框readonly ='true'

<input type="text" id="from" name="from_date" value="" readonly="true"/>
<input type="text" id="to" name="to_date" value="" readonly="true"/>