0
我有一個可以克隆的動態表單,但日期選擇器自定義範圍函數限制每個克隆的結束日期都來自第一個開始日期元素。帶有克隆表單元素的jQuery日期選擇器範圍
我正在使用SheepIt!插件克隆我的表單元素。
工作實施例:http://jsfiddle.net/YWdV7/15/
*注:添加/刪除功能在撥弄不工作,但是示例的時間範圍的限制,如前所述
爲第一日期字段和克隆功能初始功能:
當按下按鈕克隆<script type="text/javascript">
$(document).ready(function() {
var container = $('#container').sheepIt(
{
separator: '',
allowRemoveLast: true,
allowRemoveCurrent: false,
allowRemoveAll: false,
allowAdd: true,
allowAddN: false,
maxFormsCount: 10,
minFormsCount: 0,
iniFormsCount: 1
}
);
});
$(function() {
$(".date").datepicker({
showOn: "both",
buttonImage: "../../media/icons/calendar.png",
changeMonth: true,
changeYear: true,
yearRange: '2011:2050',
beforeShow: customRange
});
});
function customRange(input) {
if ($(input).hasClass('end_date')) {
var minDate = new Date($('.start_date').val());
minDate.setDate(minDate.getDate() + 1)
return {
minDate: minDate
};
}
};
</script>
功能重新啓動日期選擇器:
<script type="text/javascript">
$('#container_add').live('click', function() {
$('.date').datepicker({
showOn: "both",
buttonImage: "../../media/icons/calendar.png",
changeMonth: true,
changeYear: true,
yearRange: '2011:2050',
beforeShow: customRange
})
function customRange(input) {
if ($(input).hasClass('end_date')) {
var minDate = new Date($('.start_date').val());
minDate.setDate(minDate.getDate() + 1)
return {
minDate: minDate
};
}
};
});
</script>
兩
非常感謝您的幫助,我快到了!我的實際應用程序有額外的div(與我發佈的示例不同)。當我去添加額外的div時,自定義範圍函數不再起作用。見http://jsfiddle.net/YWdV7/23/有什麼想法? – Michael
這是一個改變選擇器的問題:http://jsfiddle.net/william/YWdV7/24/。讓自己休息一下,並閱讀[jQuery遍歷方法](http://api.jquery.com/category/traversing/)。從長遠來看,它將爲您節省大量時間。 –
感謝您的參考和幫助!我真的很感激它! – Michael