Мое приложение MVC 5, я использую следующий Нокаут-кендо выпадающий список:Нокаут-Кендо DropDownList Ajax observableArray выбран имя элемента
<input data-bind="kendoDropDownList: { dataTextField: 'name', dataValueField: 'id', data: foodgroups, value: foodgroup }" />
var ViewModel = function() {
var self = this;
this.foodgroups = ko.observableArray([
{ id: "1", name: "apple" },
{ id: "2", name: "orange" },
{ id: "3", name: "banana" }
]);
var foodgroup =
{
name: self.name,
id: self.id
};
this.foodgroup = ko.observable();
ko.bindingHandlers.kendoDropDownList.options.optionLabel = " - Select -";
this.foodgroup.subscribe(function (newValue) {
newValue = ko.utils.arrayFirst(self.foodgroups(), function (choice) {
return choice.id === newValue;
});
$("#object").html(JSON.stringify(newValue));
alert(newValue.name);
});
};
ko.applyBindings(new ViewModel());
Он прекрасно работает, благодаря этому ответу Knockout Kendo dropdownlist get text of selected item
Однако когда я изменил observableArray Аяксу:
this.foodgroups = ko.observableArray([]),
$.ajax({
type: "GET",
url: '/Meals/GetFoodGroups',
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (data) {
self.foodgroups(data);
},
error: function (err) {
alert(err.status + " : " + err.statusText);
}
});
Controller - получить таблицу из MS SQL Server:
public JsonResult GetFoodGroups()
{
var data = db.FoodGroups.Select(c => new
{
id = c.FoodGroupID,
name = c.FoodGroupName
}).ToList();
return Json(data, JsonRequestBehavior.AllowGet);
}
Я получаю эту ошибку, когда я предупрежу имя элемента
Unable to get property 'name' of undefined or null reference
В чем разница между жестко прописывать элементы массива с помощью Ajax.
Где вы получаете ошибку tis? В Ajax 'Success()'? –
Когда я пытаюсь получить имя выбранного элемента. Ajax works – hncl
Можете ли вы записать 'self.foodgroups()' после того, как вы присвоите данные 'success()'? –