Запуск события D3 для элемента

#javascript #d3.js

Вопрос:

Я прикрепил click событие к элементу диаграммы D3:

 import * as d3 from 'd3';  const vis = {} vis.svg = d3.select(element)  .append("svg")  .attr("width", 500)  .attr("height", 500) vis.g = vis.svg  .append("g") const circles = [20]; const myCircles = vis.g.selectAll('circle').data(circles).enter() myCircles  .append('circle')  .attr('id', (d, i) =gt; { return 'myCircle'   i})  .attr('cx', 100)  .attr('cy', 100)  .attr('r', (d, i) =gt; d)  .attr('fill', 'gainsboro')  .attr('stroke', 'grey')  .on('click', function(event, d) {  d3.select(this).attr('stroke', 'black')  d3.select(this).attr('stroke-width', '2px')  })  

Есть ли способ запустить это click событие извне элемента? Я пытался сделать это:

 d3.select("#myCircle0").click();  

Но это не работает. Существует ли альтернативный способ запуска события D3 для определенного элемента?

Ответ №1:

Вы должны отправить событие:

 d3.select("#myCircle0").dispatch("click");  

Вот демонстрационная версия со слегка измененным кодом, отправляющая клик в первый круг:

 const vis = {} vis.svg = d3.select("body")  .append("svg")  .attr("width", 500)  .attr("height", 500) vis.g = vis.svg  .append("g") const circles = [20, 20, 20]; const myCircles = vis.g.selectAll('circle').data(circles).enter() myCircles  .append('circle')  .attr('id', (d, i) =gt; {  return 'myCircle'   i  })  .attr('cx', (_, i) =gt; 100   50 * i)  .attr('cy', 100)  .attr('r', (d, i) =gt; d)  .attr('fill', 'gainsboro')  .attr('stroke', 'grey')  .on('click', function(event, d) {  d3.select(this).attr('stroke', 'black')  d3.select(this).attr('stroke-width', '2px')  });  d3.select("#myCircle0").dispatch("click"); 
 lt;script src="https://d3js.org/d3.v7.min.js"gt;lt;/scriptgt;