0

在这个简单的例子中:http: //jsfiddle.net/2VeGY/1/

<!doctype html>
<meta charset="utf-8">
<title>single column</title>
<style>
    *{margin:0,padding:0}
    input{width:800px;}
    nav{border:1px solid gray; width:850px;}
    li{display:inline-block; height:30px;  }
    li:hover{opacity:0.8}
</style>
<script src="http://d3js.org/d3.v3.min.js"></script>
<body>

<input value="[{&quot;v&quot;:0,&quot;c&quot;:&quot;red&quot;},{&quot;v&quot;:100,&quot;c&quot;:&quot;#005&quot;},{&quot;v&quot;:200,&quot;c&quot;:&quot;#12d&quot;}, {&quot;v&quo\
t;:300,&quot;c&quot;:&quot;#1dd&quot;}, {&quot;v&quot;:400,&quot;c&quot;:&quot;red&quot;} ]">
  <nav>
    <ul>
    </ul>
  </nav>

  <script>

  var wscale = d3.scale.linear().range(["0px","800px"])

  update()
  d3.select("input").on("change",update)

  function update(){
      var data = JSON.parse(d3.select("input").property("value"));
      var li=d3.select("ul").selectAll("li").data(data);

      wscale.domain(d3.extent(data,function(d){return d.v}))

      li.enter().append("li")

      li
        .style("width",function(d,i){
            start=d.v
            i+1 == data.length ? end=d.v : end=data[i+1].v;
            return wscale(end-start)
        })
        .style("background-image",function(d,i){
            start=d.c;
            i+1 == data.length ? end=d.c : end=data[i+1].c;
            return "linear-gradient(to right, "+start+","+end+")"});

      li.exit().remove()

  }

  </script>

您可以更改步骤的颜色比例data[...].c及其位置data[...].v。比例是动态更新的。

我的问题如下:如果第一个值不为零,为什么会搞砸?

非常感谢你的帮助!

4

2 回答 2

1

您会看到这种行为,因为在您当前的代码中,您始终将 0 作为输入值传递给wscale. 对于最后一个li元素,end将与start在您的函数中设置的相同width,因此您要传递的内容wscale将为 0。wscale考虑到价值。

您可以通过更改域的确定方式轻松解决此问题:

wscale.domain([0, d3.max(data,function(d){return d.v})]);

这假设您的所有v价值观都是积极的。

但是,您真正想要做的是考虑值之间的差异,因为这就是您传递给比例的内容。也就是说,差异的总和应该等于最大宽度。您可以按如下方式计算。

var sumdiff = 0;
for(var i = 0; i < data.length - 1; i++) {
    sumdiff += data[i+1].v - data[i].v;
}

那么尺度就变成了

wscale.domain([0, sumdiff]);

完整的例子在这里

于 2013-11-15T09:05:52.087 回答
0

你不应该把引号放在范围内,它应该是这样的:

.range([0,800])
于 2013-11-14T22:15:41.340 回答