Я попытался создать двойной список для перемещения элементов из одного в другой, а затем, наконец, передать данные из списков обратно на контроллер.Невозможно связать выбранное значение из списка
Как новичок в javascript Я борюсь с привязкой данных. Для того, чтобы переместить данные из одного ListBox к другому, я создал следующий вид:
<div class="container">
<form role="form">
<div class="container">
<div class="row">
<div class="col-md-5">
<div class="form-group">
<label for="SelectLeft">User Access:</label>
<select class="form-control" id="SelectLeft" multiple="multiple" data-bind="options : ownership, optionsText:function(item) { return item.FirstName + ' ' + item.LastName}, value:selectedItem">
@*<select class="form-control" id="SelectLeft" multiple="multiple">
</select>
</div>
</div>
<div class="col-md-2">
<div class="btn-group-vertical">
<input class="btn btn-primary" id="MoveLeft" type="button" value=" << " data-bind="click: addItem" />
<input class="btn btn-primary" id="MoveRight" type="button" value=" >> " data-bind="click: removeSelected" />
</div>
</div>
<div class="col-md-5">
<div class="form-group">
<label for="SelectRight">Owners:</label>
<select class="form-control" multiple="multiple" id="SelectRight" data-bind="options : availableOwners, optionsText:function(item) { return item.FirstName + ' ' + item.LastName}, value:selectedItem">
</select>
</div>
</div>
</div>
</div>
<button type="submit" class="btn btn-default" value="Cancel" name="addEditUser" id="btnCancel" data-bind="click: cancel">Cancel</button>
<button type="submit" class="btn btn-default" value="Submit" name="addEditUser" id="btnSubmit" data-bind="click: submit">Save</button>
</form>
</div>
<script>
var [email protected](Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(Model)));
var owners = @Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(ViewBag.AccessOwners));
var availableOwners = @Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(ViewBag.owners));
function viewModel() {
this.username=ko.observable(data.Username);
this.password=ko.observable(data.Password);
this.email=ko.observable(data.Email);
this.isActive=ko.observable(data.IsActive);
this.userId = ko.observable(data.UserId);
this.ownership=ko.observable(owners);
this.availableOwners = ko.observable(availableOwners)
this.selectedItem = ko.observable();
this.submit = function()
{
$.ajax({
url: '@Url.Action("UserSave", "Admin")',
type: 'POST',
data: ko.toJSON(this),
contentType: 'application/json',
});
window.location.href = url;
return false;
}
this.cancel = function()
{
window.location.href = url;
return false;
}
this.addItem = function() {
if ((this.selectedItem() != "") && (this.ownership.indexOf(this.selectedItem()) < 0))
{
// Prevent blanks and duplicates
this.ownership.push(this.selectedItem());
this.availableOwners.removeAll(this.selectedItem());
}
this.selectedItem(""); // Clear the text box
};
this.removeSelected = function() {
if ((this.selectedItem() != "") && (this.availableOwners.indexOf(this.selectedItem()) < 0))
{
this.ownership.removeAll(this.selectedItems());
this.availableOwners.push(this.selectedItem());
}
this.selectedItem("");
};
this.sortItems = function() {
this.ownership.sort();
this.availableOwners.sort();
};
};
ko.applyBindings(new viewModel());
var url = $("#RedirectTo").val();
Когда я нажимаю кнопку MoveLeft или MoveRight, я получаю следующее сообщение об ошибке:
Uncaught TypeError: undefined is not a function
(anonymous function)
jQuery.event.dispatch
elemData.handle
Кто-нибудь знает, как передать выбранное значение из списка в функцию addItem или removeItem, чтобы добавлять или удалять объекты из списка?
Спасибо!