我有2个选择输入,并用一系列年份填充它们。之后,我想为每个Select设置currentYear选定的值。我拥有此代码,但仅适用于第一个Select,但我不明白为什么。
编辑2
一切都适用于jQuery 1.4.3,1.4.2失败:_(
编辑
我正在尝试不成功:-(只有fisrt才选择了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>
谢谢
最佳答案
我在这里使用上面的代码进行了测试,并且可以正常工作:
$(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);
};