Javascript &引用;属性不存在于类型{}";使用带有D3 SVG符号的匿名函数时出错
我试图创建D3SVG符号,并根据数据中的category属性动态设置符号形状。这将是PowerBI中自定义可视化的一部分,因此我正在使用Typings库 从我在网上看到的示例来看,下面的代码应该可以工作Javascript &引用;属性不存在于类型{}";使用带有D3 SVG符号的匿名函数时出错,javascript,d3.js,svg,symbols,powerbi,Javascript,D3.js,Svg,Symbols,Powerbi,我试图创建D3SVG符号,并根据数据中的category属性动态设置符号形状。这将是PowerBI中自定义可视化的一部分,因此我正在使用Typings库 从我在网上看到的示例来看,下面的代码应该可以工作 var milestoneSymbols = this.milestoneContainer.selectAll('.path').data(viewModel.milestones); milestoneSymbols.enter().append('path'); milestoneSymb
var milestoneSymbols = this.milestoneContainer.selectAll('.path').data(viewModel.milestones);
milestoneSymbols.enter().append('path');
milestoneSymbols.attr('d', d3.svg.symbol()
.size(25)
.type( function(d){ return d.typeSymbol})
);
milestoneSymbols.attr("transform", function(d,i) {
return "translate("+ xScale(d.date) + ","
+ ((i % heightGroups) * (milestoneContainerHeight/heightGroups) + margins.top )
+ ")";
});
milestoneSymbols.style("stroke", "function(d) { return findTaskTypeShape(d.label).color; }
.style("stroke-width", 1)
.style("fill", function(d) { return findTaskTypeShape(d.label).color; });
但是对于代码.type(函数(d){return d.typeSymbol})
,我得到的错误是类型“{}”上不存在属性“typeSymbol”。似乎d
在type()
中不可用,因为它正在d3.svg.symbol()
代码中使用。如果我用类似“square”的字符串文字替换匿名函数,它就会工作
如何解决这个问题 Typescript对您的数据对象类型一无所知。您可以定义数据对象类型,也可以尝试使用任何类型:
milestoneSymbols.attr('d', d3.svg.symbol()
.size(25)
.type( function(d: any){ return d.typeSymbol;})
Typescript对您的数据对象类型一无所知。您可以定义数据对象类型,也可以尝试使用任何类型:
milestoneSymbols.attr('d', d3.svg.symbol()
.size(25)
.type( function(d: any){ return d.typeSymbol;})
你能用数据展示一个最小的例子吗?看起来你在用typescript。您收到的是编译错误还是运行时错误?我收到的是编译错误:
error-TYPESCRIPT/src/timeline.ts:(609,70)类型“{}”上不存在属性“typeSymbol”。
您能用数据显示一个最小的示例吗?似乎您正在使用TYPESCRIPT。您收到的是编译错误还是运行时错误?我收到的是编译错误:error TYPESCRIPT/src/timeline.ts:(609,70)类型“{}”上不存在属性“typeSymbol”。