0

我正在尝试使用此上下文菜单 javascript 库,但似乎无法在右键单击节点时触发它。

我尝试实现基本演示并且效果很好,所以我在页面上有必要的 js。

我将它添加到节点的左键单击并尝试通过自定义方式触发上下文菜单,如下所示:

graph.$('node').on('cxttapstart', function (event) {

            event.cyTarget.contextMenu();
        });

$.contextMenu({
        selector: '.context-menu-one',
        trigger: 'none',
        callback: function (key, options) {
            var m = "clicked: " + key;
            window.console && console.log(m) || alert(m);
        },
        items: {
            "edit": { name: "Edit", icon: "edit" },
            "cut": { name: "Cut", icon: "cut" },
            "copy": { name: "Copy", icon: "copy" },
            "paste": { name: "Paste", icon: "paste" },
            "delete": { name: "Delete", icon: "delete" },
            "sep1": "---------",
            "quit": { name: "Quit", icon: function ($element, key, item) { return 'context-menu-icon context-menu-icon-quit'; } }
        }
    });

但我就是不知道在网上做什么

selector: '.context-menu-one'

以便上下文菜单显示在节点旁边。

以前有人做过吗?

干杯

4

1 回答 1

2

event.cyTarget(2.x) 或event.target(3.x) 不是 dom 元素。这是一个细胞景观元素。您需要为菜单创建自己的 dom 元素(例如 div)并将其相对于node.renderedPosition()on定位cxttap

如果你想在 cytoscape 中使用上下文菜单,使用现有的扩展会更容易。

有一个具有现代圆形滑动菜单:https ://github.com/cytoscape/cytoscape.js-cxtmenu

还有一个是传统的列表菜单:https ://github.com/iVis-at-Bilkent/cytoscape.js-context-menus

于 2017-06-29T13:34:55.767 回答