我有 2 个选择输入,我用一系列年份填充它们。之后,我想为每个 Select 设置 currentYear 的选定值。我有这段代码,但只适用于第一个 Select 我不明白为什么。
编辑 2
jQuery 1.4.3 一切正常,1.4.2 失败:_(
编辑
我尝试这个没有成功:-(只有第一个选择值OK。版本中可能有问题吗?IE6,asp.net 2.0,jquery 1.4.2。例如,“$(sinceComboSelector).val(currentYear); " 不起作用我必须做一个 "$('#cmbAnyDesde option[value=' + currentYear + ']').attr('selected', 'selected');" :-(
代码更新:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Tests.aspx.cs" Inherits="Tests" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script src="../JAVASCRIPT/jquery-1.4.2.min.js" type="text/javascript"></script>
</head>
<body>
<script type="text/javascript">
$(document).ready(function() {
loadYears();
});
var loadYears = function() {
var currentYear = new Date().getFullYear(),
years = [],
firstYear = currentYear - 7,
lastYear = currentYear + 3,
sinceComboSelector = "#cmbAnyDesde",
toComboSelector = "#cmbAnyHasta",
i;
for (i = firstYear; i <= lastYear; i++) {
years.push(i);
}
$(sinceComboSelector).find('option').remove();
$(toComboSelector).find('option').remove();
$.each(years, function(key, value) {
$(sinceComboSelector)
.append($("<option></option>")
.attr("value", value)
.text(value));
$(toComboSelector)
.append($("<option></option>")
.attr("value", value)
.text(value)); ;
});
// $(sinceComboSelector).val(currentYear);
// $(toComboSelector).val(currentYear);
$('#cmbAnyDesde option[value=' + currentYear + ']').attr('selected', 'selected');
$('#cmbAnyHasta option[value=' + currentYear + ']').attr('selected', 'selected');
};
</script>
<form id="form1" runat="server">
<div>
<select id="cmbAnyDesde" style="width:70px"></select>
<select id="cmbAnyHasta" style="width:70px"></select>
</div>
</form>
</body>
</html>
谢谢