4

我无法理解 Webstorm IDE 中的以下 TypeScript 错误消息(TypeScript 很新,很抱歉......)

我正在使用DefinitelyTyped存储库中的d3.d.ts来使用d3js实现图形,其中d3.svg.arc()方法的接口定义如下:

export interface Arc { 
...
outerRadius: {
            (): (data: any, index?: number) => number;
            (radius: number): Arc;
            (radius: () => number): Arc;
            (radius: (data: any) => number): Arc;
            (radius: (data: any, index: number) => number): Arc;
        };
 ...
 }

当以下列方式实现弧时......

svg.selectAll(".arc")    
            .attr("d", function (d) {
                       return d3.svg.arc().outerRadius(
                              function (d) {
                                 return d - 9;
                              })
                        ...

我收到错误:“参数类型函数不可分配给参数类型函数”

所以

 function (d) {return d - 9;})

似乎对该接口无效,即使它看起来是类型

 (): (data: any, index?: number) => number;

我想我监督了一些明显的事情......我现在卡住了

谢谢

4

1 回答 1

4

我在字符串到数字的转换方面遇到了类似的问题,并通过添加显式类型转换来修复它,例如:

$.replace(/text/g, <string>$.now());.

只需注意<string>参数之前的。

只需尝试进行类型转换并告诉它是如何进行的。

在您的情况下,它将类似于:

svg.selectAll(".arc")    
        .attr("d", function (d) {
                   return d3.svg.arc().outerRadius(
                          <Function>function (d) {
                             return d - 9;
                          })
                    ...

或者可能:

svg.selectAll(".arc")    
        .attr("d", function (d) {
                   return d3.svg.arc().outerRadius(
                          <function>function (d) {
                             return d - 9;
                          })
                    ...

因为错误在于Functionfunction之间的差异。

于 2013-10-24T18:51:54.137 回答