javascript - How to config contextmenu for different typs of nodes in jstree? - Stack Overflow

I use 'contextmenu' and 'types' plugin in jstree and want to define different conte

I use 'contextmenu' and 'types' plugin in jstree and want to define different contextmenu according to the 'types', like this:

$("#tree").jstree({
    "plugins" : [ "themes", "json_data", "ui", "contextmenu", "types" ],
    "themes" : {
        "url" : "css/jstree/themes/classic/style.css",
        "theme" : "classic",
        "icons" : false
    },
    "json_data" : { "data" : data },
    "types": {
        "types": {
            "leaf": { "contextmenu" : { items : contextMenu } }
        }
    }
});

but it doesn't work, it displays the same contextmenu for all nodes, no specified one as I defined for 'leaf' nodes. Is it because cannot define contextmenu in type? Then how to achieve this easily.

I use 'contextmenu' and 'types' plugin in jstree and want to define different contextmenu according to the 'types', like this:

$("#tree").jstree({
    "plugins" : [ "themes", "json_data", "ui", "contextmenu", "types" ],
    "themes" : {
        "url" : "css/jstree/themes/classic/style.css",
        "theme" : "classic",
        "icons" : false
    },
    "json_data" : { "data" : data },
    "types": {
        "types": {
            "leaf": { "contextmenu" : { items : contextMenu } }
        }
    }
});

but it doesn't work, it displays the same contextmenu for all nodes, no specified one as I defined for 'leaf' nodes. Is it because cannot define contextmenu in type? Then how to achieve this easily.

Share Improve this question asked Mar 9, 2012 at 2:14 denceydencey 1,06117 silver badges25 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 7

You have to define the context menu in the context menu plugin section. I think the best way at the moment is to define all items for all nodes and then delete items according to the node type, or even better - define a function that returns the context menu according to the node. i.e, this is how you'd usually define the contextmenu without a function:

    "contextmenu" : {
        items: {
            "some_action" : {
                "label" : "Do something",
                "action"            : function (obj) { this.do_action(obj); },
                "_disabled"         : function (obj) { 
                    // here you can decide if you want to show the item but disable it
                }
            };
            // define more items
        };
         if (data.rslt.o.attr("rel") == "no_action") {
            delete items.some_action;
        }
    return items;
}

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1744838849a4596430.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信