我有两个用于拖放的自定义绑定,并且有一个我需要放入可放置区域的元素列表,但是当发生这种情况时,我需要从源列表中删除拖动的元素,我正在做以下方式,但是当从源列表中删除被拖动的元素时,我收到以下错误“无法获取属性'选项的值':对象为空或未定义”,并且调试器在我的jquery-ui中断。 1.8.17.min.js文件,在这一行var d=a(this).data("draggable").options
中。拖动绑定中会出现问题。
这是我的代码:
var viewModelInstance = new ViewModel();
$(document).ready(function () {
$(window).load(
function () {
var _dragged;
ko.bindingHandlers.drag = {
init: function (element, valueAccessor, allBindingsAccessor, viewModel) {
var dragElement = $(element);
var dragOptions = {
helper: 'clone',
revert: true,
start: function () {
_dragged = ko.utils.unwrapObservable(valueAccessor().value);
},
cursor: 'default'
};
dragElement.draggable(dragOptions).disableSelection();
}
};
ko.bindingHandlers.drop =
{
init: function (element, valueAccessor, allBindingsAccessor, viewModel) {
var dropElement = $(element);
var dropOptions = {
drop: function (event, ui) {
var folder = dropElement[0].innerText;
viewModelInstance.UpdateCandidate(_dragged, viewModel, folder);
viewModelInstance.candidates.remove(_dragged);
}
};
dropElement.droppable(dropOptions);
}
};
ko.applyBindings(viewModelInstance);
});
}
);
});
答案 0 :(得分:0)
尝试使用detach()而不是remove()。
答案 1 :(得分:0)
我设法通过添加" setTimeout"来解决错误。让knockout操作在knockout之前完成从列表中删除元素。
在您的情况下,代码更改应该类似于:
drop: function (event, ui) {
var folder = dropElement[0].innerText;
setTimeout( function(){
viewModelInstance.UpdateCandidate(_dragged, viewModel, folder);
viewModelInstance.candidates.remove(_dragged);
},10);
}
希望这适合你:)