代码之家  ›  专栏  ›  技术社区  ›  four-eyes

通过D3添加的DOM元素未显示

  •  -2
  • four-eyes  · 技术社区  · 6 年前

    createLegend() ).

    http://jsfiddle.net/gs6rehnx/2045/

    <button type="button" onclick="createPie()">Click Me First!</button>
    <button type="button" onclick="updatePie()">Update Diagram!</button>
    <div class='foo'></div>
    
    
    const width = 260;
    const height = 260;
    const thickness = 40;
    const duration = 750;
    
    const radius = Math.min(width, height) / 2;
    const color = d3.scaleOrdinal(d3.schemeCategory10);
    
    const arc = d3
      .arc()
      .innerRadius(radius - thickness)
      .outerRadius(radius);
    
    const pie = d3
      .pie()
      .value(function(d) {
        return d.value;
      })
      .sort(null);
    
    
    const create = function(data) {
      const svg = d3
        .select('.foo')
        .append('svg')
        .attr('class', 'pie')
        .attr('width', width)
        .attr('height', height)
        .attr('id', 'svgClass');
    
      svg
        .append('g')
        .attr('transform', 'translate(' + width / 2 + ',' + height / 2 + ')')
        .attr('id', 'bar');
        createLegend();
      draw(data);
    }
    
    const draw = function(data) {
      const path = d3.select('#bar')
        .selectAll('path')
        .data(pie(data))
    
      path
        .enter()
        .append('g')
        .append('path')
        .attr('d', arc)
        .attr('fill', (d, i) => color(i));
    
      path
        .transition()
        .duration(duration)
        .attrTween('d', function(d) {
          const interpolate = d3.interpolate({
            startAngle: 0,
            endAngle: 0
          }, d);
          return function(t) {
            return arc(interpolate(t));
          };
        });
    };
    
    const createLegend = function() {
        d3.select('#svgClass')
      .append('text')
      .text('foo bar')
      .attr('position', 'relative')
      .attr('background-color', 'red')
      .attr('top', '50px')
      .attr('left', '50px')
    }
    
    
    const data = [{
        name: 'USA',
        value: 50
      },
      {
        name: 'UK',
        value: 5
      },
      {
        name: 'Canada',
        value: 5
      },
      {
        name: 'Maxico',
        value: 40
      }
    ]
    
    function createPie() {
      create(data)
    }
    
    const newData = [{
        name: 'USA',
        value: 40
      },
      {
        name: 'UK',
        value: 20
      },
      {
        name: 'Canada',
        value: 30
      },
      {
        name: 'Maxico',
        value: 10
      }
    ];
    
    function updatePie() {
      draw(newData)
    }
    

    它正在电视上播放 DOM tree 当我检查图表时。然而,它并没有出现在网站上。为什么?

    2 回复  |  直到 6 年前
        1
  •  1
  •   Shashank    6 年前

    SVG text docs 学习如何将定位应用于 text

    你看不到这篇文章的原因是它完全超出了范围。CSS定位不是定位文本的方法。使用属性 x y 或使用 transform SVG transform ).

    createLegend

    d3.select('#svgClass')
      .append('text')
      .text('foo bar')
      .attr('x', width/2).attr('y', height/2).style('fill', 'red');
    

    现在我看到你在试图添加 background-color 到文本 可以使用 rect 在课文后面。举个例子: d3 way of adding a background to texts

    代码段:

    const width = 260;
    const height = 260;
    const thickness = 40;
    const duration = 750;
    
    const radius = Math.min(width, height) / 2;
    const color = d3.scaleOrdinal(d3.schemeCategory10);
    
    const arc = d3
      .arc()
      .innerRadius(radius - thickness)
      .outerRadius(radius);
    
    const pie = d3
      .pie()
      .value(function(d) {
        return d.value;
      })
      .sort(null);
    
    
    const create = function(data) {
      const svg = d3
        .select('.foo')
        .append('svg')
        .attr('class', 'pie')
        .attr('width', width)
        .attr('height', height)
        .attr('id', 'svgClass');
    
      svg
        .append('g')
        .attr('transform', 'translate(' + width / 2 + ',' + height / 2 + ')')
        .attr('id', 'bar');
    	createLegend();
      draw(data);
    }
    
    const draw = function(data) {
      const path = d3.select('#bar')
        .selectAll('path')
        .data(pie(data))
    
      path
        .enter()
        .append('g')
        .append('path')
        .attr('d', arc)
        .attr('fill', (d, i) => color(i));
    
      path
        .transition()
        .duration(duration)
        .attrTween('d', function(d) {
          const interpolate = d3.interpolate({
            startAngle: 0,
            endAngle: 0
          }, d);
          return function(t) {
            return arc(interpolate(t));
          };
        });
    };
    
    const createLegend = function() {
    	d3.select('#svgClass')
      .append('text')
      .text('foo bar').attr('x', width/2).attr('y', height/2).style('fill', 'red');
    }
    
    
    const data = [{
        name: 'USA',
        value: 50
      },
      {
        name: 'UK',
        value: 5
      },
      {
        name: 'Canada',
        value: 5
      },
      {
        name: 'Maxico',
        value: 40
      }
    ]
    
    function createPie() {
      create(data)
    }
    
    const newData = [{
        name: 'USA',
        value: 40
      },
      {
        name: 'UK',
        value: 20
      },
      {
        name: 'Canada',
        value: 30
      },
      {
        name: 'Maxico',
        value: 10
      }
    ];
    
    function updatePie() {
      draw(newData)
    }
    <script src="https://d3js.org/d3.v4.min.js"></script>
    
    <button type="button" onclick="createPie()">Click Me First!</button>
    <button type="button" onclick="updatePie()">Update Diagram!</button>
    <div class='foo'></div>

    希望这有帮助。

        2
  •  0
  •   Ian    6 年前

    这一切都归结为HTML和SVG之间的差异。不幸的是,您需要使用一些不同的属性。

    首先 left top 不正确,您要使用 x y 分别。

    其次是 background-color 不起作用,请尝试应用 stroke 或者 fill 你的短信。