Kendo UI DragAndDrop TreeView项目到ListView

时间:2013-05-07 16:17:05

标签: drag-and-drop kendo-ui kendo-treeview

我需要启用从kendo-ui树视图拖放到模板化列表视图。 我尝试了以下内容:

1.在树视图上启用dragAndDrop并将listview配置为kendoDropTarget

2.在树视图上禁用dragAndDrop,而是将该控件配置为kendoDraggable到配置为kendoDropTarget的listview

<div>
<div id="treeview">        
</div></div>   


<div id="favorites-window" style="height:185px;width:1170px">
<div class="report-reader" style="height:185px;width:1170px;overflow:auto">
    <div id="listView"></div>
</div>                            
</div>

    $("#favorites-window").kendoWindow({
    width: "1180",
    height: "185",
    resizable: false,
    draggable: false,        
    actions: ["Custom"],
    title: "Favorites"
});
$("#listView").kendoListView({
    selectable: "single",
    navigatable: false
}).kendoDropTarget({
    drop: function (e) {
        console.log(e);
        var item = getObjects(nucleusTreeJsonData, 'text', e.draggable.hint.text());
        $("#listView").data("kendoListView").dataSource.add(item);
    }
});

var inlineDefault = new kendo.data.HierarchicalDataSource({
                data: [
                    { text: "Furniture", items: [
                        { text: "Tables & Chairs" },
                        { text: "Sofas" },
                        { text: "Occasional Furniture" }
                    ] },
                    { text: "Decor", items: [
                        { text: "Bed Linen" },
                        { text: "Curtains & Blinds" },
                        { text: "Carpets" }
                    ] }
                ]
            });


    $("#treeview").kendoTreeView({
        dragAndDrop: true,
        dataSource: inlineDefault,
        dataTextField: "text"

    });
        //.kendoDraggable({
    //    container: $("#tree-pane"),
    //    hint: function () {
    //        return $("#treeview").clone();
    //    },
    //    dragstart: draggableOnDragStart
    //});

    $("#treeview").data("kendoTreeView").bind("dragstart", function (e) {
        if ($(e.sourceNode).parentsUntil(".k-treeview", ".k-item").length == 0) {
            e.preventDefault();
        }
    });

    /*$("#treeview").data("kendoTreeView").bind("drop", function (e) {
            e.preventDefault();
            var copy = this.dataItem(e.sourceNode).toJSON();
            if (e.dropPosition == "over") {
                //var item = getObjects(nucleusTreeJsonData, 'text',   e.sourceNode.textContent);
                $("#listView").data("kendoListView").add(copy);
            }
    });*/

    $('ul.k-group.k-treeview-lines div').children().css('font-weight', 'bold').find('div').css('font-weight', 'normal');

我没有太多运气。请看看我的小提琴。任何建议将不胜感激

http://jsfiddle.net/OhenewaDotNet/JQBZN/16/

2 个答案:

答案 0 :(得分:1)

我知道这是一个老问题,但我也有,所以我继续使用这个小提琴想出来。

http://jsfiddle.net/JQBZN/74/

这是非常基本的,可能是非常好的架构,但我认为它至少证明了关键点:

$("#treeview").kendoTreeView({
    dragAndDrop: true,
    dataSource: inlineDefault,
    dataTextField: "text",
    drag: function (e) {
        /* Manually set the status class. */
        if (!$("#treeview").data('kendoTreeView').dataItem(e.sourceNode).hasChildren && $.contains($('#favorites-window')[0], e.dropTarget)) {
            e.setStatusClass('k-add');
        } else {
            e.setStatusClass('k-denied');
        }
    },
    drop: function (e) {
        if (e.valid) {
            /* Do your adding here or do it in a drop function elsewhere if you want the receiver to dictate. */
        }
        e.preventDefault();
    }
});

答案 1 :(得分:0)

如果KendoUI工具集没有按照您的意愿执行,您可能会发现使用jQuery UI更容易做到您想做的事情。他们都在实现相同的jQuery核心库。

如果你使用jQuery UI,只需将'draggable'绑定到你想要拖动的元素,然后'droppable'到你的目标。从那里,您可以连接处理程序以执行您想要的任何操作。

我已经设置了一个简单的jsFiddle来演示它是如何工作的:

http://jsfiddle.net/e2fZk/23/

jQuery代码非常简单:

$(".draggable").draggable();
$(".container").droppable({
    drop: function (event, ui) {
        var $target = $(this);
        var $source = ui.draggable;
        var newUrl = $source.find("input").val();
        alert("dropped on " + $target.attr("id") + ", setting URL to " + newUrl);
        $target.find("#imageDiv").html("<img id='myImage' />")
            .find("#myImage").attr("src", newUrl);
    }
});

API文档在这里:

Draggable

Droppable