Reactjs 类型';字符串';不可分配给类型';绝不';和类型';未知';不可分配给类型';绝不';反应类型脚本中的错误
我在React Typescript中有一个函数Reactjs 类型';字符串';不可分配给类型';绝不';和类型';未知';不可分配给类型';绝不';反应类型脚本中的错误,reactjs,typescript,function,Reactjs,Typescript,Function,我在React Typescript中有一个函数 const filter = (data: any) => { if (Array.isArray(data)) { const temp = data.reduce((r, v) => { v = filter(v); if (v !== "") r.push(v); return r; }, []); return te
const filter = (data: any) => {
if (Array.isArray(data)) {
const temp = data.reduce((r, v) => {
v = filter(v);
if (v !== "") r.push(v);
return r;
}, []);
return temp.length ? temp : "";
}
if (data && typeof data === "object") {
const temp = Object.entries(data).reduce((r, [k, v]) => {
v = filter(v);
if (v !== "") r.push([k, v]);
return r;
}, []);
return temp.length ? Object.fromEntries(temp) : "";
}
return data;
};
但是在这里,
if(v!=“”)r.push([k,v])代码>我收到错误类型“string”不可分配给类型“never”。ts(2322)
和类型“unknown”不可分配给类型“never”。ts(2322)
分别位于k
和v
中,但我没有找到任何解决这些问题的方法。我是Typescript新手。Typescript无法在reduce中找出正确的r
,因此它假定它是从不[]
。您可以通过自己指定正确的类型来解决这个问题
const filter = (data: any) => {
if (Array.isArray(data)) {
const temp = data.reduce((r, v) => {
v = filter(v);
if (v !== "") r.push(v);
return r;
}, []);
return temp.length ? temp : "";
}
if (data && typeof data === "object") {
const temp = Object.entries(data).reduce((r, [k, v]) => {
v = filter(v);
if (v !== "") r.push([k, v]);
return r;
}, [] as [string, unknown][]);
return temp.length ? Object.fromEntries(temp) : "";
}
return data;
};