如何使用livevalidation验证信用卡到期日期(2个字段)

时间:2011-11-09 01:13:49

标签: javascript validation livevalidation

在自定义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> 

2 个答案:

答案 0 :(得分:0)

好吧 - 我终于想通了......在那里使用了一点php并抓住了当月的当前价值...

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
}

否则,从服务器传递月份和年份(例如在隐藏的输入中)并对其进行测试。