D3 4.9.1为.style返回不同​​的值(" transform")

时间:2017-07-11 10:44:02

标签: javascript d3.js

在d3 4.9.1如果我打电话来获得具有这样风格的元素的变换:

<g style="transform: translateX(3.84559px);"></g>

操作:

d3.select(this).style("transform")

d3v4.9.1中的输出:

translateX(3.84559px)

但是在d3v4.8.0中它有不同的输出:

matrix(1, 0, 0, 1, 3.84559, 0)

导致此问题的新版本是否有任何变化?

我有找到转换属性的不同参数的功能,现在已经破坏了:

contents.getTransformation = function (transform) {
    // console.log(transform);
    var g = document.createElementNS("http://www.w3.org/2000/svg", "g");
    g.setAttributeNS(null, "transform", transform);
    var matrix = g.transform.baseVal.consolidate().matrix;
    var a = matrix.a;
    var b = matrix.b;
    var c = matrix.c;
    var d = matrix.d;
    var e = matrix.e;
    var f = matrix.f;
    var scaleX = Math.sqrt(a * a + b * b);
    var scaleY = Math.sqrt(c * c + d * d);
    var skewX = a * c + b * d;
    if (scaleX) {
        a /= scaleX;
        b /= scaleX;
    }
    if (skewX) {
        c -= a * skewX;
        d -= b * skewX;
    }
    if (scaleY) {
        c /= scaleY;
        d /= scaleY;
        skewX /= scaleY;
    }
    if (a * d < b * c) {
        a = -a;
        b = -b;
        skewX = -skewX;
        scaleX = -scaleX;
    }
    return {
        translateX: e,
        translateY: f,
        rotate: Math.atan2(b, a) * Math.PI / 180,
        skewX: Math.atan(skewX) * Math.PI / 180,
        scaleX: scaleX,
        scaleY: scaleY
    };
};

参考:Replacing d3.transform in D3 v4

1 个答案:

答案 0 :(得分:3)

v4.9.0的发行说明有:

  

更改selection.style以返回内联样式(如果存在)。

由于您在<g>上指定了内联样式,因此在使用版本v4.9.1时将返回此值。先前版本始终返回计算样式。