如何将 QTip 设置为始终在 Cytoscape.js 中显示工具提示

How to set QTip to always show tooltips in Cytoscape.js

我正在寻找一种让 QTip 同时显示 Cytoscape.js 图中每个节点的工具提示的方法,以便它们始终显示并锚定到图中的节点,而无需用户单击或将鼠标悬停在节点上。

我接近了下面的代码:

$(document).ready(function(){
            cy.nodes().qtip({
                content: function(){ return 'Station: ' + this.id() +
                                       '</br> Next Train: ' + this.data('nextTrain') +
                                       '</br> Connections: ' + this.degree();
                        },
                hide: false,
                show: {
                    when: false,
                    ready: true
                 }
            })
        })

上面的代码在 $(document).ready 上显示工具提示,但它们都位于 Cytoscape 图中的一个节点,当我放大或平移时它们会消失。

目标是将工具提示锚定到图表中的每个节点,这样当我放大和平移时,它们会固定在该节点上。我不确定仅使用 Cytoscape(即多功能标签)是否有更简单的方法来做到这一点。

我正在使用 Qtip2、jQuery-2.0.3 和 cytoscape.js

的最新版本

非常感谢任何帮助。

编辑: 如果要自动创建这些元素,请使用函数和循环遍历 cy.nodes():

var makeTippy = function (nodeTemp, node) {
    return tippy(node.popperRef(), {
        html: (function () {
            let div = document.createElement('div');
            // do things in div
            return div;
        })(),
        trigger: 'manual',
        arrow: true,
        placement: 'right',
        hideOnClick: false,
        multiple: true,
        sticky: true
    }).tooltips[0];
};
var nodes = cy.nodes();
for (var i = 0; i < nodes.length; i++) {
    var tippy = makeTippy(nodes[i]);
    tippy.show();
}

如果您想要粘性 qTip,我会推荐 popper.js 的 cytoscape 扩展,特别是 tippy 版本 (粘性 div):

document.addEventListener('DOMContentLoaded', function() {
  var cy = window.cy = cytoscape({
    container: document.getElementById('cy'),
    style: [{
        selector: 'node',
        style: {
          'content': 'data(id)'
        }
      },
      {
        selector: 'edge',
        style: {
          'curve-style': 'bezier',
          'target-arrow-shape': 'triangle'
        }
      }
    ],
    elements: {
      nodes: [{
          data: {
            id: 'a'
          }
        },
        {
          data: {
            id: 'b'
          }
        }
      ],
      edges: [{
        data: {
          source: 'a',
          target: 'b'
        }
      }]
    },
    layout: {
      name: 'grid'
    }
  });
  var a = cy.getElementById('a');
  var b = cy.getElementById('b');
  var makeTippy = function(node, text) {
    return tippy(node.popperRef(), {
      html: (function() {
        var div = document.createElement('div');
        div.innerHTML = text;
        return div;
      })(),
      trigger: 'manual',
      arrow: true,
      placement: 'bottom',
      hideOnClick: false,
      multiple: true,
      sticky: true
    }).tooltips[0];
  };
  var tippyA = makeTippy(a, 'foo');
  tippyA.show();
  var tippyB = makeTippy(b, 'bar');
  tippyB.show();
});
body {
  font-family: helvetica neue, helvetica, liberation sans, arial, sans-serif;
  font-size: 14px
}

#cy {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
}

h1 {
  opacity: 0.5;
  font-size: 1em;
  font-weight: bold;
}


/* makes sticky faster; disable if you want animated tippies */

.tippy-popper {
  transition: none !important;
}
<!DOCTYPE>
<html>

<head>
  <title>Tippy > qTip</title>
  <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
  <script src="https://unpkg.com/cytoscape/dist/cytoscape.min.js"></script>
  <script src="https://unpkg.com/popper.js"></script>
  <script src="cytoscape-popper.js"></script>
  <script src="https://unpkg.com/tippy.js@2.0.9/dist/tippy.all.js"></script>
  <link rel="stylesheet" href="https://unpkg.com/tippy.js@2.0.9/dist/tippy.css" />
  <script src="https://cdn.jsdelivr.net/npm/cytoscape-popper@1.0.2/cytoscape-popper.js"></script>
</head>

<body>
  <h1>cytoscape-popper tippy demo</h1>
  <div id="cy"></div>
</body>

</html>

我认为 popper 在有 div 时更容易处理 'stick around'