[英]How to type a JavaScript function with JSDoc + TypeScript?
[英]JSDoc typings for typescript for JavaScript reducer accumulator
我正在尝试使用 JSDocs 在 JavaScript reducer
键入累加器,但无法弄清楚如何执行此操作。
我试过在初始化时内联输入它,但这没有用。 任何提示或想法? 这是示例代码。 它抱怨传递给 arr.push() 的参数:
/**
* @type {Array<String>}
*/
const arr = ['one', 'two', 'three'];
/**
* @type {Array<Array>}
*/
const result = arr.reduce((acc, item) => {
if(item.length % 3 === 0) {
// [ts] Argument of type '(string | number)[]' is not assignable to
// parameter of type 'never'.
acc.push([item, item.length]);
}
return acc;
}, []);
这是 GitHub 存储库,它在 tsc 设置的项目根目录中有tsconfig.json
文件: https : //github.com/guyellis/typescript-as-a-linter
这是我从中获取上述代码的那个 repo 中的文件: https : //github.com/guyellis/typescript-as-a-linter/blob/master/lib/reducer.js
您作为初始状态传递的空数组的类型为never[]
。 有关更多背景信息,请参阅此线程。 为了避免这种情况,你可以把它放在一个常量中并给常量一个类型:
/**
* @type {Array<String>}
*/
const arr = ['one', 'two', 'three'];
/** @type {Array<[string, number]>} */
const init = [];
/**
* @type {Array<[string, number]>}
*/
const result = arr.reduce((acc, item) => {
acc.push([item, item.length]);
return acc;
}, init);
/**
* @param {Pose['parameterValues']} values
* @param {Pose['variants']} variants
*/
function getSrc (values, variants) {
return values.reduce(
/** @param {{[key: string]:Array<string>}} paths */
(paths, { camera, light }, index) => {
paths[light.name] = []
for (let c = camera.start; c < camera.end; c += camera.increment) {
paths[light.name].push(
variants[index].replace('light', light.value).replace('camera', String(c))
)
}
return paths
}, {})
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.