猿问

如何修复 d3 中的多刷图表

我太近了,这快要了我的命。我已经为一列生成了一个简单的画笔,它生成了完美设置的限制。问题是我想要多列 ['A'、'B'、'C'、'D'] 的多个画笔。我可以把它写四次,但我把它放在一个似乎不起作用的函数中。请查看下面的工作代码,我已经注释掉了不起作用的部分。我知道我需要以某种方式绑定数据并进行循环,但我该如何有效地做到这一点?

var margin = {

    top: 20,

    right: 20,

    bottom: 30,

    left: 50

  },

  width = 960 - margin.left - margin.right,

  height = 180 - margin.top - margin.bottom;


var x = d3.scale.ordinal()

  .domain(["A", "B", "C", "D"])

  .rangeBands([0, 200])


var y = d3.scale.linear()

  .range([height, 0])

  .domain([0, 100])


var xAxis = d3.svg.axis()

  .scale(x)


var svg = d3.select("#timeline").append("svg")

  .attr("width", width + margin.left + margin.right)

  .attr("height", height + margin.top + margin.bottom)

  .append("g")

  .attr("transform", "translate(" + margin.left + "," + margin.top + ")");



// define brush control element and its events

var brush = d3.svg.brush().y(y)

  .on("brushend", () => console.log('A Extent: ', brush.extent()))


// create svg group with class brush and call brush on it

var brushg = svg.append("g")

  .attr("class", "brush")

  .call(brush);


// set brush extent to rect and define objects height

brushg.selectAll("rect")

  .attr("x", x("A"))

  .attr("width", 20);


/*


var brush = (d) => {

    var brush = d3.svg.brush().y(y)    

                      .on("brushend", () => console.log(d, ' Extent: ', brush.extent()))

      

    var brushg = svg.append("g")

        .attr("class", "brush")

        .call(brush1);


    brushg.selectAll("rect")

        .attr("x", x("A"))

        .attr("width", 20);

 }

 */

.brush {

  fill: lightgray;

  fill-opacity: .75;

  shape-rendering: crispEdges;

}

<script src='https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.6/d3.min.js'></script>

<div class="container">

  <div id="timeline"></div>

</div>



慕田峪7331174
浏览 135回答 1
1回答

MM们

将画笔视为数据,因为它们映射到 x 轴上的每个序数值。使用 .enter 创建画笔并附加所有必要的功能。.each 函数类似于调用,但分别在每个元素上运行。这对于包含画笔的生成非常有用。xData = ["A", "B", "C", "D"];var margin = {&nbsp; &nbsp; top: 20,&nbsp; &nbsp; right: 20,&nbsp; &nbsp; bottom: 30,&nbsp; &nbsp; left: 50&nbsp; },&nbsp; width = 960 - margin.left - margin.right,&nbsp; height = 180 - margin.top - margin.bottom;var x = d3.scale.ordinal()&nbsp; .domain(xData)&nbsp; .rangeBands([0, 200])var y = d3.scale.linear()&nbsp; .range([height, 0])&nbsp; .domain([0, 100])var xAxis = d3.svg.axis()&nbsp; .scale(x)var svg = d3.select("#timeline").append("svg")&nbsp; .attr("width", width + margin.left + margin.right)&nbsp; .attr("height", height + margin.top + margin.bottom)&nbsp; .append("g")&nbsp; .attr("transform", "translate(" + margin.left + "," + margin.top + ")");&nbsp;&nbsp;const brushes = svg.selectAll('g.brush')&nbsp; .data(xData)&nbsp; .enter()&nbsp; .append('g')&nbsp; .attr('class', 'brush')&nbsp; .each(function(d) {&nbsp; &nbsp; const el = d3.select(this);&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; const brush = d3.svg.brush().y(y).on("brushend", () => console.log(d, ' Extent: ', brush.extent()));&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; el.call(brush);&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; el.selectAll("rect")&nbsp; &nbsp; &nbsp; .attr("x", x(d))&nbsp; &nbsp; &nbsp; .attr("width", 20);&nbsp; &nbsp;});.brush {&nbsp; fill: lightgray;&nbsp; fill-opacity: .75;&nbsp; shape-rendering: crispEdges;}<script src='https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.6/d3.min.js'></script><div class="container">&nbsp; <div id="timeline"></div></div>
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答