Vis.js网络图不随节点更改而更新

Vis.js network graph not updating with node changes

本文关键字:更新 节点 js 网络 Vis      更新时间:2023-09-26

我有一个函数,可以清除节点或边缘数据集中可能存在的任何数据,并继续用新数据重新填充它们。这是一个分层网络,在创建所有节点和边之后,级别是动态设置的,因此节点的级别属性最终是由 nodes.update() 调用添加。
节点的级别设置正确,可以在我的控制台日志中看到,但图表没有反映级别。不显示任何错误。看到节点似乎是正确的,我不认为这是设置级别的方法的问题,但我能想到的唯一可能干扰的其他事情是在像我这样的角度工厂中使用它,nodes.update() 不触发图形的重新渲染,或者我的选项。任何见解都值得赞赏,因为我真的不知道为什么设置级别不会改变我的图表。

很抱歉缺少信息。我只是不知道从哪里开始,也不想分享我的整个文件。

网络工厂:

var nodes, edges, network;
visApp.factory('networkFactory', function() {
    var service = {};
    service.init = function() {
        // create an array with nodes
        nodes = new vis.DataSet();
        // create an array with edges
        edges = new vis.DataSet();
        // create a network
        var container = document.getElementById('callFlow');
        var data = {
            nodes: nodes,
            edges: edges
        };
        var options = {
            physics: false,
            nodes: {
                shape: 'box',
                size: 25
            },
            edges: {
                smooth: {
                    type: 'cubicBezier',
                    roundness:.75
                }
            },
            layout: {
                hierarchical: {
                    direction: 'LR',
                    sortMethod: 'directed'
                }
            },
            interaction: {
                navigationButtons: true
            }
        };
        network = new vis.Network(container, data, options);
    };
    service.updateVis = function(profile) {
        try {
            console.log("updating network...");
            clearNetwork();
            addNodesFromProfile(profile);
            addEdgesFromProfile(profile);
            console.log("setting hierarchical levels");
            setLevels("ENTRY", 1, 1);
            console.log("network updated:'n" + JSON.stringify(nodes.get()));
        }
        catch(err) {alert(err)}
    };

控制台.log:

updating network...
adding nodes
adding edges
setting hierarchical levels
network updated:
[{"id":"mainMenu","label":"mainMenu","level":4},{"id":"broadcast","label":"broadcast","level":3},{"id":"greeting","label":"greeting","level":2},{"id":"salesMenu","label":"salesMenu","level":5},{"id":"exitAssurance","label":"exitAssurance","level":5},{"id":"EXIT","label":"EXIT","level":7},{"id":"exitArchitecture","label":"exitArchitecture","level":6},{"id":"exitSalesEast","label":"exitSalesEast","level":6},{"id":"exitCXAnalytics","label":"exitCXAnalytics","level":6},{"id":"servicesMenu","label":"servicesMenu","level":5},{"id":"exitSalesWest","label":"exitSalesWest","level":6},{"id":"exitOther","label":"exitOther","level":5},{"id":"ENTRY","label":"ENTRY","level":1}]

add

network.body.emitter.emit('_dataChanged')

以前

network.redraw()

nodes.update()后,您可以使用network.redraw()函数刷新视图。