2

我正在尝试将 Kendo UI MVVM 框架与 Kendo UI 拖放机制一起使用;但是我很难找出如何从draggable对象中删除数据。

我的代码是这样的......

var viewModel = kendo.observable {
    Cart : [],
    Items : [
    {
      Id : "item/10",
      Name: "CD ROM"
    },
    {
      Id : "item/11",
      Name: "DVD ROM"
    }
};

那么我有一个粗略的模板绑定......

<script id="products-template" type="text/x-kendo-template">
    <li class="draggable">
        <div data-bind="text: Name"></div>
    </li>
</script>

然后在列表中调用它......

<div id="shopping-items-available">
   <ul data-template="products-template" data-bind="source: Items">
   </ul>
</div>

然后有一个标准的“放置目标”(取自剑道文档)

<div id="droptarget">Start dragging.</div>

使用以下 CSS

#droptarget {
    border: 1px solid #959595;
    height: 198px;
    width: 300px;
    font-size: 36px;
    border-radius: 37px;
    text-align: center;
    line-height: 198px;
    color: #a1a1a1;
    text-shadow: 0 1px 1px #fff;
    margin: 0 0 30px 220px;
    cursor: default;
    background: #dddddd;
    background: -moz-linear-gradient(top, #dddddd 0%, #c1c1c1 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#dddddd), color-stop(100%,#c1c1c1));
    background: -webkit-linear-gradient(top, #dddddd 0%,#c1c1c1 100%);
    background: -o-linear-gradient(top, #dddddd 0%,#c1c1c1 100%);
    background: -ms-linear-gradient(top, #dddddd 0%,#c1c1c1 100%);
    background: linear-gradient(top, #dddddd 0%,#c1c1c1 100%);
}

现在在 javascript 中,我将shopping-items-availablediv 转换为draggable.

    $("body").kendoDraggable({
        hint: function (target) {
            return $(target).clone().addClass("draggable");
        },
        filter: ".draggable"
    });

最后,我初始化放置目标。

    $("#droptarget").kendoDropTarget({
        drop: droptargetOnDrop
    });

但在我的代码中,我似乎无法获得有关被丢弃项目的实际数据。

    function droptargetOnDrop(e) {
        console.log(e);
        $("#droptarget").text("You did great!");
        $(".draggable").removeClass("hollow");
    }
4

1 回答 1

5

被丢弃的项目的数据由droptargetOnDropas接收e.draggable.currentTarget

如果要将项目移动到目标区域,您应该执行以下操作:

$("#droptarget").append(e.draggable.currentTarget);

注意这样做,您将移动该项目。如果要附加副本,则应附加节点的克隆:

 $("#droptarget").append($(e.draggable.currentTarget).clone());

编辑:为了在不使用 kendoDataSource 的情况下获取数据项,我建议将模板更改为:

<script id="products-template" type="text/x-kendo-template">
    <li class="draggable" data-id="${Id}">
        <div data-bind="text: Name"></div>
    </li>
</script>

这会在被拖动的 DOM 中保存Id(或任何允许您找到后者元素的信息)。然后在处理程序中,我们检索Id并搜索与该 对应的项目Id

function droptargetOnDrop(e) {
    var dom = e.draggable.currentTarget;
    var id = $(dom).data("id");
    var items = viewModel.Items;
    for (var i = 0; i < items.length; i++) {
        if (items[i].Id == id) {
            alert("Found : " + JSON.stringify(items[i]));
            break;
        }
    }
}

编辑如果您决定使用kendoListView,您应该将您的模板定义为:

<script id="products-template" type="text/x-kendo-template">
    <li class="draggable">
        <div>${Name}</div>
    </li>
</script>

列表的 HTML 容器将是:

    然后将 ListView 初始化为:

    var list = $("#shopping-items-available > ul").kendoListView({
        template  : $("#products-template").html(),
        dataSource: viewModel.Items
    }).data("kendoListView");
    

    最后是droptargetOnDrop功能:

    function droptargetOnDrop(e) {
        var dom = e.draggable.currentTarget;
        var item = list.dataSource.getByUid(dom.data("uid"));
        alert("Found : " + JSON.stringify(item));
    }
    
    于 2013-08-07T22:38:58.470 回答