我正在使用重力表单数据选择器,如果值等于" Framingham",则需要根据表单顶部的选择字段禁用日期范围。我非常确定我需要销毁日期选择器并在更改时重新初始化它,但我并不完全确定。如果" Framingham"未选择则45天应为30天。这是我能得到的:
jQuery(function(){
jQuery('#input_3_23').on('change', function(){
if(jQuery(this).val() == 'Framingham'){
for(var i=0; i<45; i++){
var day=new Date(year, month, date + i);
disabledDays.push(("0" + (day.getMonth() + 1)).slice(-2) + '/' + ("0" + day.getDate()).slice(-2) + '/' + day.getFullYear() );
}
gform.addFilter( 'gform_datepicker_options_pre_init', function( optionsObj, formId, fieldId ) {
if (formId == 3 && fieldId == 14 || formId == 3 && fieldId == 15 || formId == 3 && fieldId == 16) {
optionsObj.minDate = 0;
optionsObj.beforeShowDay = function(date) {
var checkdate = jQuery.datepicker.formatDate('mm/dd/yy', date);
return [disabledDays.indexOf(checkdate) == -1];
};
}
return optionsObj;
});
}
});
});
我还有一个用户可选的disableDays数组,这是
的位置return [disabledDays.indexOf(checkdate) == -1];
来自。任何帮助都会非常感激!
答案 0 :(得分:0)
不太优雅但更简单的解决方案可能是在表单中添加两个日期字段。一个是45天的帽子,另一个是30天的帽子。然后你可以使用Gravity Forms&#39;条件逻辑,根据您在下拉字段中选择的值显示/隐藏相应的日期字段。
如果你走这条路线,你可能也会对GP Limit Dates感兴趣,这样你就可以在没有任何自定义代码的情况下限制日期范围。