Как настроить контекстное меню для разных типов узлов в jstree? - PullRequest
3 голосов
/ 09 марта 2012

Я использую плагин contextmenu и types в jstree и хочу определить разные contextmenu в соответствии с типами, например:

$("#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 } }
        }
    }
});

, но он не работает, он отображаетодно и то же контекстное меню для всех узлов, не указано ни одного, как я определил для «конечных» узлов.Это потому, что не может определить contextmenu в типе?Тогда как этого легко добиться.

1 Ответ

7 голосов
/ 09 марта 2012

Вы должны определить контекстное меню в разделе плагина контекстного меню.Я думаю, что лучший способ на данный момент - определить все элементы для всех узлов, а затем удалить элементы в соответствии с типом узла или, что еще лучше, определить функцию, которая возвращает контекстное меню в соответствии с узлом.то есть, как вы обычно определяете контекстное меню без функции:

    "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;
}
...