0

我正在尝试根据用户选择禁用和启用验证。在我的解决方案中,我只想验证用户是否输入了开始日期或结束日期。到目前为止,如果您查看我的部分解决方案代码,我会进行一些验证。我将提出几个关于我需要它如何工作的场景。

场景1(工作)

用户不输入日期,不需要验证

场景2(工作)

用户输入开始或结束日期。这将验证文本框。

方案 3(不工作)

用户输入开始和结束日期。单击搜索。然后清除两个日期字段和验证是这两个文本框的显示方式。我希望此时隐藏验证。到目前为止,我能做到这一点的唯一方法是清除文本框,然后再次点击搜索。

提前致谢!

4

1 回答 1

1

看到这个链接

我的仅验证是否输入了日期,如果日期选择器字段为空,则会从 kendo 隐藏所有验证标签。

它满足您上面描述的场景,除了我发布成功的表格。

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Kendo UI Snippet</title>

    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.common.min.css">
    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.rtl.min.css">
    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.default.min.css">
    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.dataviz.min.css">
    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.dataviz.default.min.css">
    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1119/styles/kendo.mobile.all.min.css">

    <script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
    <script src="http://cdn.kendostatic.com/2014.3.1119/js/kendo.all.min.js"></script>
</head>
<body>

<form id="myform">
    <input name="myDate" class="validateDate" id="startDate" /> <br />
    <input name="myDate" class="validateDate" id="endDate" />
    <button>Validate</button>
</form>

<script>
    $("#myform").kendoValidator({
      rules: {
        dateValidation: function(input) {
          //only validate
          if (input.hasClass('validateDate')) {
            if(input.val() !== ""){
                return kendo.parseDate(input.val(), "dd/MM/yyyy");  
            }
            else{
              input.siblings("span.k-tooltip-validation").hide(); 
                return true; 
            }
          }
        }
      },
      messages: {
        dateValidation: "Please enter a date in the format dd/mm/yyyy"
      }
    });
  $("#startDate, #endDate").kendoDatePicker({ format: "dd/MM/yyyy", culture: "en-GB" })
</script>
</body>
</html>
于 2015-01-16T16:03:48.153 回答