在自定义PHP捐赠页面上使用http://livevalidation.com。我想让过去的信用卡exp日期无效,但所有其他选项都有效。我在月份和年份使用两个选择字段。
似乎应该使用validate.custom或validate.now函数来完成,但是文档中没有关于这些函数的好例子。似乎无法让他们工作......
<select tabindex="4" id="exp_month" name="exp_month">
<option value="01">01</option>
<option value="02">02</option>
<option value="03">03</option>
<option value="04">04</option>
<option value="05">05</option>
<option value="06">06</option>
<option value="07">07</option>
<option value="08">08</option>
<option value="09">09</option>
<option value="10">10</option>
<option value="11">11</option>
<option value="12">12</option>
</select>
<select tabindex="5" id="exp_year" name="exp_year">
<option value="11">2011</option>
<option value="12">2012</option>
<option value="13">2013</option>
<option value="14">2014</option>
<!-- etc -->
</select>
<script>
var exp_year = new LiveValidation( "exp_year", { validMessage: " ", failureMessage: "Enter a valid exp date", onlyOnSubmit: true } );
exp_year.add( Validate.Custom(
// ????
);
</script>
答案 0 :(得分:0)
var exp_year = new LiveValidation( "exp_year", { validMessage: " ", failureMessage: "Enter a valid exp date", onlyOnSubmit: true } );
exp_year.add( Validate.Custom, { against: function(value){
var currentyymm=<?php print date(ym) ?>;
var expmo1=document.getElementById("exp_month").selectedIndex;
var expmo2=document.getElementById("exp_month").options;
if (value+expmo2[expmo1].value >= currentyymm) { return true; }
else { return false; }
}, failureMessage: "Enter a valid exp date" } );
答案 1 :(得分:0)
如果您信任用户的系统时钟,那么就像:
var d = new Date();
var y0 = d.getFullYear();
var m0 = d.getMonth() + 1;
var y1 = document.getElementById('exp_year').value;
var m1 = document.getElementById('exp_month').value;
if (y0 == y1 && m0 < m1) {
// selected date is in the past
}
否则,从服务器传递月份和年份(例如在隐藏的输入中)并对其进行测试。