我正在尝试在表单中自动选择月,日和年。我确信这很简单,但我对Javascript很不熟悉。在月份以下的代码中,选择工作正常,但是实际日期总是+1,而年份根本不起作用。如果有人可以提供帮助,将非常感谢!谢谢!
<form name="form" action="b.html" method="post">
<select id="month" name="month">
<option id="1" value="January">January</option>
<option id="2" value="February">February</option>
<option id="3" value="March">March</option>
<option id="4" value="April">April</option>
<option id="5" value="May">May</option>
<option id="6" value="June">June</option>
<option id="7" value="July">July</option>
<option id="8" value="August">August</option>
<option id="9" value="September">September</option>
<option id="10" value="October">October</option>
<option id="11" value="November">November</option>
<option id="12" value="December">December</option>
</select>
/
<select id="day" name="day">
<option id="1" value="1">1</option>
<option id="2" value="2">2</option>
<option id="3" value="3">3</option>
<option id="4" value="4">4</option>
<option id="5" value="5">5</option>
<option id="6" value="6">6</option>
<option id="7" value="7">7</option>
<option id="8" value="8">8</option>
<option id="9" value="9">9</option>
<option id="10" value="10">10</option>
<option id="11" value="11">11</option>
<option id="12" value="12">12</option>
<option id="13" value="13">13</option>
<option id="14" value="14">14</option>
<option id="15" value="15">15</option>
<option id="16" value="16">16</option>
<option id="17" value="17">17</option>
<option id="18" value="18">18</option>
<option id="19" value="19">19</option>
<option id="20" value="20">20</option>
<option id="21" value="21">21</option>
<option id="22" value="22">22</option>
<option id="23" value="23">23</option>
<option id="24" value="24">24</option>
<option id="25" value="25">25</option>
<option id="26" value="26">26</option>
<option id="27" value="27">27</option>
<option id="28" value="28">28</option>
<option id="29" value="29">29</option>
<option id="30" value="30">30</option>
<option id="31" value="31">31</option>
</select>
/
<select id="year" name="year">
<option id="2012" value="2012">2012</option>
<option id="2013" value="2013">2013</option>
<option id="2014" value="2014">2014</option>
<option id="2015" value="2015">2015</option>
<option id="2016" value="2016">2016</option>
<option id="2017" value="2013">2017</option>
<option id="2018" value="2014">2018</option>
<option id="2019" value="2015">2019</option>
<option id="2020" value="2016">2020</option>
</select>
<script>
var d = new Date();
var month = d.getMonth();
var day = d.getDate();
var year = d.getFullYear();
document.form.month[month].selected = month;
document.form.day[day].selected = day;
document.form.year[year].selected = year;
</script>
</form>
答案 0 :(得分:1)
你有ids冲突! ID是页面上的奇异值。 Selected是一个布尔值,您将其设置为数字。
摆脱ids,
var d = new Date();
var month = d.getMonth();
var day = d.getDate();
var year = d.getFullYear();
document.form.month.options[month].selected = true;
document.form.day.options[day-1].selected = true;
document.form.year.options[year-2012].selected = true;
答案 1 :(得分:1)
此代码:
var day = d.getDate();
...
document.form.year[year].selected = true;
应该是
var day = d.getDate()-1;
...
document.form.year[year - 2012].selected = true;
这一天必须减1,因为这部分:document.form.day[day]
是一个数组,记住数组从0开始,但getDate()
从1开始。
为什么你不需要为月份减去1?因为JavaScript Date Object's month index begins with 0!
答案 2 :(得分:0)
select元素中的选项由从[0]开始的索引访问。
导致:
document.form.month[0].value is 'January'
document.form.day[0].value is 1;
document.form.year[0].selected is 2012;
请务必正确计算索引或将项目的值用作索引:
var year = d.getFullYear();
document.getElementById('year').value = year;
请从您的选项中删除“id”属性。在文档中使用相同的id两次是不好的做法。它应该是唯一的元素。
答案 3 :(得分:0)
请在此处查看我的工作解决方案:http://jsfiddle.net/powtac/gVWrz/7/
document.form.month[month].selected = true;
document.form.day.value = day;
document.form.year.value = year;
答案 4 :(得分:-2)
您正尝试通过各自的索引访问元素。当您访问月份时,巧合的是它会显示正确的月份,因为getMonth()
会在1月份返回0
。当您选择第三个月(index = 2)时,它正确选择March作为index=2
的元素。
对于日期和年份,我将代码更改为.value
。您不能在月份执行此操作,因为您使用的值是1月,2月,3月等,而不是他们的索引。
<script>
var d = new Date();
var month = d.getMonth();
var day = d.getDate();
var year = d.getFullYear();
document.form.month.options[month].selected = true;
document.form.day.value = day;
document.form.year.value = year;
</script>