1

我与看似简单的问题斗争了半天,但无济于事,所以我很想从 stackoverflow 天才那里得到一些好的建议。

我在http://62.165.130.126/d3-question有一个演示

我试图将它放入 jsfiddle 但无法正确获取库,希望这仍然可以让您深入了解。

当旋转文本消失时,问题在 d3.js javascript 代码中显示出来。或者实际上是旋转文本的一部分。

页面上的每一对条都应该有两行旋转 45 度(下坡)的文本,以免覆盖相邻的文本。如果我不旋转文本,一切都是可见的(但重叠),但如果我这样做,只有第一对行是可以的。之后,第一个文本消失了(或者在某些版本上错放了几十个像素,看似随意),但第二个文本就在它应该使用完全相同的代码结构的地方。我已经交换了值,问题与值无关,而是与顺序有关。

这是我编写的 javascript 中的主要代码。

$.each(data, function(a_key,a_val){
            $.each(a_val, function(form_key,form_val){
                $.each(form_val, function(person_key,person_val){
                    svg.append("rect")
                .attr("x", start*2*width+width)
                .attr("y", 420-person_val.val1/person_val.val1_max*400)
                .attr("width", width-5)
                .attr("height", person_val.val1/person_val.val1_max*400)
                .style("fill", "red");
            svg.append("rect")
                .attr("x", start*2*width)
                .attr("y", 420-person_val.val2/person_val.val2_max*400)
                .attr("width", width-5)
                .attr("height", person_val.val2/person_val.val2_max*400)
                .style("fill", "green");
            svg.append("text")
                        .attr("text-anchor", "start")
                        .attr("transform","translate(" + start*2*width+20  + ",430) rotate(45)")
                        .style("font-size","0.85em")
                        .text(person_val.pname);
                    svg.append("text")
                        .attr("text-anchor", "start")
                        .attr("transform","translate(" + start*2*width  + ",430) rotate(45)")
                        .style("font-size","0.85em")
                        .text(person_val.ptype);
                    start++;
                });
            });

该应用程序只是真实解决方案的模型,但应无干扰地显示基本问题。每对条形图下方应有描述文本。目前他们还没有居中,但如果事情解决了,那么改变应该是直截了当的。

有人知道如何更正代码吗?

4

1 回答 1

1

问题在于"translate(" + start*2*width+20 + ",430) rotate(45)"代码。结果之一是translate(8020,430) rotate(45)。Javascript变成20 了字符串。尝试在start*2*width+20表达式周围放置大括号。

于 2016-08-15T17:08:53.083 回答