d3.js 动画选择子元素

import * as D3 from 'd3'

export default class DThree {
  createSvgG (result) {
    let svg = D3.select(result)
      .append('svg')
      .attr('width', 400)
      .attr('height', 400)
    let g = svg.append('g')
    g.append('rect')
    g.append('rect')
    let selectG = D3.select('g')
    selectG.transition()
      .attr('x', 50)
  }
  createSvgGTwo (result) {
    let dataset = [100, 100, 100]
    let g = D3.select(result).append('svg')
      .attr('width', 400)
      .attr('height', 400)
      .append('g')
    let rect = g.selectAll('rect')
      .data(dataset)
      .enter()
      .append('rect')
      .attr('fill', 'steelblue')
      .attr('id', function (d, i) {
        return 'rect' + i
      })
      .attr('width', function (d, i) {
        return d
      })
      .attr('height', 30)
      .attr('x', 10)
      .attr('y', function (d, i) {
        return 10 + i * 35
      })
    console.log(rect)
    // g.transition()
    //   .duration(2000)
    //   .select('#rect1')
    //   .attr('width', 300)
    // g.selectAll('rect')
    //   .transition()
    //   .attr('width', 300)
    g.transition()
      .selectAll('rect')
      .filter(function (d, i) {
        return i >= 1
      })
      .attr('width', 300)
  }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值