1

在自定义 PHP 捐赠页面上使用http://livevalidation.com 。我想让过去的信用卡过期日期无效,但所有其他选择都有效。我为月份和年份使用了两个选择字段。

似乎这应该使用 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> 
4

2 回答 2

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" } ); 
于 2011-11-09T16:57:28.247 回答
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
}

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

于 2011-11-10T05:55:10.543 回答