У меня есть 3 выпадающих списка, чтобы показать дату начала (день / месяц / год). У меня есть еще 3, чтобы показать дату окончания.
Я хочу подтвердить это
- Пользователь выбирает действительную дату (т. Е. Не 30 февраля). Если они выберут недопустимую дату, предупредите («Ваша дата недействительна».)
- что разница в днях между начальной и конечной датами меньше 7.
Я действительно борюсь с этим и надеялся, что кто-нибудь может помочь мне как относительный новичок.
Пока мой код выглядит следующим образом:
<script type="text/javascript">
var monthtext=["01","02","03","04","05","06","07","08","09","10","11","12"];
function populatedropdown(dayfield, monthfield, yearfield){
var today=new Date()
var dayfield=document.getElementById(dayfield)
var monthfield=document.getElementById(monthfield)
var yearfield=document.getElementById(yearfield)
for (var i=0; i<=31; i++)
dayfield.options[i]=new Option(i, i)
dayfield.options[today.getDate()]=new Option(today.getDate(), today.getDate(), true, true) //select today's day
for (var m=0; m<12; m++)
monthfield.options[m]=new Option(monthtext[m], monthtext[m])
monthfield.options[today.getMonth()]=new Option(monthtext[today.getMonth()], monthtext[today.getMonth()], true, true) //select today's month
var thisyear=today.getFullYear()
for (var y=0; y<4; y++){
yearfield.options[y]=new Option(thisyear, thisyear)
thisyear+=1
}
yearfield.options[0]=new Option(today.getFullYear(), today.getFullYear(), true, true) //select today's year
}
</script>
HTML:
<label>Start date :</label>
<select name="startDateDay" id="startDaydropdown"></select>
<select name="startDateMonth" id="startMonthdropdown"></select>
<select name="startDateYear" id="startYeardropdown"></select>
<label>End date :</label>
<select name="endDateDay" id="endDaydropdown"></select>
<select name="endDateMonth" id="endMonthdropdown"></select>
<select name="endDateYear" id="endYeardropdown"></select>