我在另一个下拉列表的on change事件上创建了Select,所以这是我的脚本:
$ddlOther.on('change', function(e) {
var Json = {},
persons = [];
Json.id = $(this).val();
$.post('/PersonController/GetPersonDDL', Json, function(data) {
drivers = data;
}, 'json').done(function(data) {
$person.select2({
placeholder: "Select Persons(s)",
allowClear: true,
multiple: true,
data: persons
});
});
});
这是我的控制器方法:
public ActionResult GetPersonDDL(JsonDictionary args)
{
JsonResult result = null;
string id= args["id"].Trim();
var persons = _context.Persons
.Where(x => x.id== id)
.Select(x => new
{ x.first_name,
x.middle_name,
x.last_name, x.id
}).ToList();
foreach (var person in persons)
{
var item = new SelectListItem
{
Text = string.Format("{0} - {1} {2} {3}",
person.id,
person.first_name,
person.middle_name,
person.last_name),
Value = person.id
};
list.Add(item);
}
result = Json(list.Select(x=>new {value = x.Text,
id = x.Value}
), JsonRequestBehavior.AllowGet);
return result;
}
我收回了数据,但是控制台(在这种情况下是firebug)给了我错误:
TypeError: a is undefined
返回的JSON
看起来像这样:
[
Object { value="John Doe", id="1"},
Object { value="Jane Doe" id="2"}
]
答案 0 :(得分:0)
Select2需要[{text="john doe",id="1"},{text="jane doe",id="2"}]
,
所以在我的控制器中,我只是将其改为返回:
result = Json(list.Select(x=>new {value = x.Text,
id = x.Value}
), JsonRequestBehavior.AllowGet);
现在可以通过更改控制器来工作,但如果您需要,请为文本指定其他名称,您可以更改Select2的文本参数:
text : 'value'
,
但是我没有按照这种方式工作,所以如果有人知道的话,请打电话。