У меня есть фрагмент кода, в котором я пытаюсь определить символ и цвет для динамического использования на основе переданного параметра (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) + ")"; });
Если я удалю условную логику sybmol и просто d строго к одному или другому символу, все будет работать, но я не могу понять, почему добавление условной логики вызывает проблемы. Вот ошибка:
Ошибка: атрибут d: Ожидается команда moveto path ('M' или 'm'), "функция n (n, r) {…



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Используйте отдельную функцию для создания символов и назовите ее
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>
поскольку вам нужно вызвать функцию для генерации символа
return d3.svg.symbol().type("cross")(d);, что делает<в средней строке?