• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

187
Views
Cytoscape, nodos de diseño basados en campos de datos personalizados

Tengo un gráfico cytoscape.js, tengo 2 tipos de nodos. Quiero diseñar los nodos según la clase.

Tengo esto hasta ahora:

 cy = cytoscape({ container: document.getElementById("cy"), style: [ { selector: 'node', style: { 'background-color': 'green', 'label': 'data(_label)', 'shape': 'hexagon', } }, { selector: '.server', style: { 'background-color': 'red', 'shape': 'square' } }, { selector: '.db', style: { 'background-color': 'blue', 'shape': 'triangle' } }, { selector: 'edge', style: { 'width': 3, 'line-color': '#fff', 'target-arrow-color': '#fff', 'target-arrow-shape': 'triangle', 'curve-style': 'bezier', } } ], elements: { nodes: [ { data: { id: 'a', _label: 'zzz', type: 'node'}, classes: 'db'}, { data: { id: 'b', _label: 'b', type: 'node'}, classes: 'server'}, { data: { id: 'c', _label: 'c', type: 'node'}, classes: 'server'}, { data: { id: 'd', _label: 'd', type: 'node'}, classes: 'server'}, { data: { id: 'e', _label: 'e', type: 'node'}, classes: 'server'}, { data: { id: 'k', _label: 'k', type: 'node'}, classes: 'server'}], edges: [ { data: { id: 'ab', source: 'a', target: 'b', type: 'edge'}}, { data: { id: 'bc', source: 'b', target: 'c', type: 'edge'}}, { data: { id: 'bd', source: 'b', target: 'd', type: 'edge'}}, { data: { id: 'ae', source: 'a', target: 'e', type: 'edge'}}, { data: { id: 'ek', source: 'e', target: 'k', type: 'edge'}}] }});

Cuando se carga el gráfico, todo funciona bien. Veo 2 triángulos azules y el resto son cuadrados rojos, como esperaba.

Tengo un código que muestra un cuadro de diálogo cuando el usuario selecciona el tipo de cambio desde un menú contextual, elidí ese código, pero el controlador se ve así:

 var foo = cy.$("#"+selectedNode.id); foo.removeClass(foo.classes()[0]); foo.addClass(newType); // wher newType here is either 'server' or 'db'

Esto funciona la primera vez que trato de cambiar algo. es decir, puedo cambiar un servidor a una base de datos, y cambia de un cuadrado rojo a un triángulo azul, o viceversa. Sin embargo, solo funciona una vez. Si trato de cambiar una segunda vez (ya sea el mismo nodo o un nodo diferente), obtengo un hexágono verde todo el tiempo.

¿Por qué solo funciona una vez?

Supongo que de alguna manera estoy corrompiendo el gráfico, no se registran errores en la consola.

about 3 years ago · Juan Pablo Isaza
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error