Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Array.map() and D3 selection?

Is there anything like Array.map() for a D3 selection? To find the maximum length of a selection of SVG <text/> elements, I currently do the following. However .selectAll(...)[0].map(...) seems like a hack to me. Is there a better way?

      var chi = svg.selectAll('.chi');

      var xChi = d3.max(chi[0].map(function (itm) { return itm.getComputedTextLength(); }));

I can use selection.each() to iterate a function over a selection, but I'm not sure how to combine this with d3.max(). I tried d3.max(chi.each(function (itm) { return itm.getComputedTextLength(); })), but d3.each() doesn't return an array of the return values

like image 893
user916968 Avatar asked Aug 30 '12 07:08

user916968


2 Answers

var allLength

d3.selectAll(".element")
.each(function(d, i) {allLength[i]=d3.select(this).node().getComputedTextLength() })

var maxLength = d3.max(a)
like image 105
Paulo Avatar answered Nov 08 '22 00:11

Paulo


Yea..that bracket makes my eyes sore too.

d3.max(svg.selectAll('.chi').pop(), function(item) {
  return itm.getComputedTextLength()
})

The question was from 2012. I don't know what d3 was like back then, but the current version has d3.max accepts an accessor function to retrieve the value you're max-ing.

like image 24
ming_codes Avatar answered Nov 08 '22 00:11

ming_codes