我有一个反应成分。我想在此组件中设置状态,该状态将向下传递给子组件。我对此有参考错误,我不确定为什么。
export const WidgetToolbar: React.FC<{}> = () => {
this.state = {
targetBox:null,
}
const isOpen = useBehavior(mainStore.isWidgetToolbarOpen);
const themeClass = useBehavior(mainStore.themeClass);
const userDashboards = useBehavior(dashboardStore.userDashboards);
const [filter, setFilter] = useState("");
const [sortOrder, setSortOrder] = useState<SortOrder>("asc");
const userWidgets = useMemo(() => {
let _userWidgets = values(userDashboards.widgets).filter((w) => w.widget.isVisible);
if (sortOrder === "asc") {
_userWidgets.sort((a, b) => a.widget.title.localeCompare(b.widget.title));
} else {
_userWidgets.sort((a, b) => b.widget.title.localeCompare(a.widget.title));
}
if (!isBlank(filter)) {
_userWidgets = _userWidgets.filter((row) => {
return row.widget.title.toLowerCase().includes(filter.toLocaleLowerCase());
});
}
return _userWidgets;
}, [userDashboards, sortOrder, filter]);
...
这是我得到的错误:
TypeError: Cannot set property 'state' of undefined
at WidgetToolbar (WidgetToolbar.tsx?ba4c:25)
at ProxyFacade (react-hot-loader.development.js?439b:757)
答案 0 :(得分:4)
功能组件中没有this
或this.state
。使用useState挂钩,类似于您在下面的几行中所做的操作。
export const WidgetToolbar: React.FC<{}> = () => {
const [targetBox, setTargetBox] = useState<null | whateverTheTypeIs>(null);
//...
}
答案 1 :(得分:1)
功能性React组件不能具有状态。您必须使用基于类的组件才能获得状态。
https://guide.freecodecamp.org/react-native/functional-vs-class-components/
您已使用钩子在此功能中“使用状态”:const [filter, setFilter] = useState("");
您可以对targetBox
执行相同的操作,而不是尝试在不存在的'this'上设置属性