因此,在更改一个下拉列表时,我试图填充第二个列表。
我有这个客户端功能:
$('#ProjectReference').change(function() {
var url = "@Url.Action("GetProjectIterations", "Rally")";
var data = { selectedProject: $('#ProjectReference').val() };
$.getJSON(url, data, function(iterations) {
alert("hello?");
var items;
$.each(iterations, function(i, iteration) {
items += "<option value='" + iteration.Name + "'>" + iteration.Name + "</option>";
});
}
);
$.ajax({
url: url,
type: 'GET',
dataType: 'json',
data: data,
contentType: 'application/json; charset=utf-8',
success: function (iterations) {
alert("hello?");
var items;
$.each(iterations, function(i, iteration) {
items += "<option value='" + iteration.Name + "'>" + iteration.Name + "</option>";
});
$("#ProjectIteration").html(items);},
failure: function () { alert("nope");}
});
});
我已经尝试了 2 种不同的格式来调用我的控制器(所以我知道我不需要两者 - 我只是将两者都包括在内以突出我尝试过的内容)。
我的控制器被调用,我正在返回数据,但我的警报都没有被触发(我试图更新的下拉列表没有任何反应)。所以也许我返回数据的方式不正确?我的选择列表计数为 33,因此在返回之前似乎有数据。
public ActionResult GetProjectIterations(string selectedProject)
{
var projectIterations = cache.Get("ProjectIterations") as Hashtable;
var iterations = (projectIterations[selectedProject] as ArrayList).Cast<DynamicJsonObject>().ToList();
var selectList = iterations.Select(
iteration => new SelectListItem {Text = iteration["Name"], Value = iteration["Name"]});
return Json(selectList);
}