【发布时间】:2014-10-08 05:27:25
【问题描述】:
我有一个 Datepicker,因为用户可能会在文本框中写入无效字符,所以我想要进行 datepicker 验证。
这是我的表格:
@using (Html.BeginForm("Action", "Controller", FormMethod.Post))
{
@Html.TextBox("txtDate", txtDate, "{0:dd.MM.yyyy}", new { @class = "date", id = "txtDate" })
<input type="submit" id="btnSubmit" value="Getir" />
}
第一个问题: 我的日期像“dd.MM.yyyy”,但在这个脚本代码中它像“mm/dd/yyyy”。如何格式化这个脚本代码,如“dd.MM.yyyy”?
第二个问题: 如果我的日期验证是错误的,我该如何禁用按钮点击提交?
这里是脚本代码和its link.
$(function() {
$('#btnSubmit').bind('click', function(){
var txtVal = $('#txtDate').val();
if(isDate(txtVal))
alert('Valid Date');
else
alert('Invalid Date');
});
function isDate(txtDate)
{
var currVal = txtDate;
if(currVal == '')
return false;
var rxDatePattern = /^(\d{1,2})(\/|-)(\d{1,2})(\/|-)(\d{4})$/; //Declare Regex
var dtArray = currVal.match(rxDatePattern); // is format OK?
if (dtArray == null)
return false;
//Checks for mm/dd/yyyy format.
dtMonth = dtArray[1];
dtDay= dtArray[3];
dtYear = dtArray[5];
if (dtMonth < 1 || dtMonth > 12)
return false;
else if (dtDay < 1 || dtDay> 31)
return false;
else if ((dtMonth==4 || dtMonth==6 || dtMonth==9 || dtMonth==11) && dtDay ==31)
return false;
else if (dtMonth == 2)
{
var isleap = (dtYear % 4 == 0 && (dtYear % 100 != 0 || dtYear % 400 == 0));
if (dtDay> 29 || (dtDay ==29 && !isleap))
return false;
}
return true;
}
});
【问题讨论】:
标签: javascript jquery asp.net-mvc validation datepicker