javascript - 有条件地设置 d3 符号

标签 javascript d3.js

我有一段代码,我试图根据传入的参数(0 或 1)动态确定要使用的符号和颜色。但是,当我尝试设置逻辑时,出现属性 d 的路径错误。代码如下

  svg.selectAll(".point")
      .data(data)
    .enter()
      .append("path")
      .attr("class", "point")
      .attr("d", function(d){
        if(d.zeroOrOne == 1){
          return d3.svg.symbol().type("cross");
        }else if (d.zeroOrOne == 0){
          return d3.svg.symbol().type("circle");
        }
      })<
      .attr('fill', 'none')
      .attr('stroke', function(d){
        if(d.zeroOrOne == 1){
          return 'blue';
        }else if (d.zeroOrOne == 0){
          return 'red';
        }
      })
      .attr("transform", function(d) { return "translate(" + ratingScale(d.xParam) + "," + winsNomsScale(d.yParam) + ")"; });

如果我删除条件符号逻辑并严格限制一个符号或另一个符号,则一切正常,但我无法弄清楚为什么添加条件逻辑会导致问题。错误如下:

错误:属性 d:预期的移动路径命令('M' 或 'm'),“函数 n(n,r){...

最佳答案

使用单独的函数来创建符号并调用它

var data = [{"zeroOrOne" : 0 }, {"zeroOrOne" : 1 }, {"zeroOrOne" : 2 }];

// use this for generating symbols
var arc = d3.svg.symbol().type(function(d) { 
	if(d.zeroOrOne == 0) {
		return "circle";
	}
	else if(d.zeroOrOne == 1) {
		return "cross";
	}
	else return "triangle-up";
});

 d3.select("#graph").selectAll(".point")
      .data(data)
    .enter()
      .append("path")
      .attr("class", "point")
      .attr("d", arc)
      .attr('fill', 'none')
      .attr('stroke', function(d){
        if(d.zeroOrOne == 1){
          return 'blue';
        }else if (d.zeroOrOne == 0){
          return 'red';
        }
		else return "green";
      })
      .attr("transform", function(d, i) { return "translate(" + (i + 1) * 20 + " ,30 )"; });
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.11/d3.min.js"></script>
<svg id="graph" width="200", height="200" >
</svg>

关于javascript - 有条件地设置 d3 符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52571485/

相关文章:

javascript - D3.js 与维基百科的集成

java - 使用 Rhino 从 Clojurescript 生成 Java 类

javascript - 将传单缩放级别与 d3 地理比例相匹配

javascript - Angularjs:在运行时在下拉列表中定义列

javascript - 使用 jquery 更改 CSS 适用于 .parent().addClass 而不仅仅是 .addClass

javascript - d3 转换后调用函数

javascript - 如何使用调度事件 d3js 更新图表中的轴

javascript - 使用 D3 .datum() 向元素添加属性

javascript - Strapi 上传的文件未显示在网站上

javascript - 是否有可能将所有全局/继承的 css 类应用于一个元素?