使用Kendo UI Dragunder的Kendo UI MVVM

时间:2013-08-07 20:51:22

标签: kendo-ui kendo-mvvm

我正在尝试使用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-available div转换为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");
    }

1 个答案:

答案 0 :(得分:5)

被删除项目的数据由droptargetOnDrop收到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));
}