【发布时间】:2019-10-16 04:43:00
【问题描述】:
我正在阅读 React 文档,它建议如果你有一些会经常更改的道具,一个好的生命周期方法是shouldComponentUpdate。
我的问题是您如何将useEffect 方法与如下功能组件一起使用?
这是我的功能组件:
function GenericIsUserLoggedInLink({ isLoggedIn, logOutUser, route, anchorText }) {
const [setProps] = useState({isLoggedIn: isLoggedIn, route: route, anchorText:anchorText });
console.log('setProps', setProps);
useEffect((nextProps, nextState) => {
if (setProps.isLoggedIn !== nextProps.setProps.isLoggedIn) {
return true;
}
if (setProps.route !== nextProps.setProps.route) {
return true;
}
if (setProps.anchorText !== nextProps.setProps.anchorText) {
return true;
}
return false;
});
if (isLoggedIn) {
if (anchorText === undefined) {
return <Link href="/"><a onClick={() => logOutUser()}>Log out!</a></Link>
} else if (anchorText) {
return <Link href={route}><a >{anchorText}</a></Link>
}
} else {
if (route === "/login") {
return <Link href="/login"><a >Log in!</a></Link>
}
return null
}
}
这是我的想法,但它没有用!哈!有没有人可以提供见解?
更新 我遵照 Shubham 的处方,但遇到了这个问题?
所以我这样做了... 但感觉很hacky: 我想这不是因为我正在利用lexical scoping
var comparator;
const GenericIsUserLoggedInLink = React.memo(({ isLoggedIn, logOutUser, route, anchorText }) => {
comparator = (prevProps, nextProps) => {
if (prevProps.isLoggedIn !== nextProps.setProps.isLoggedIn) {
return true;
}
if (prevProps.isLoggedIn !== nextProps.setProps.route) {
return true;
}
if (prevProps.anchorText !== nextProps.setProps.anchorText) {
return true;
}
return false;
}
if (isLoggedIn) {
if (anchorText === undefined) {
return <Link href="/"><a onClick={() => logOutUser()}>Log out!</a></Link>
} else if (anchorText) {
return <Link href={route}><a >{anchorText}</a></Link>
}
} else {
if (route === "/login") {
return <Link href="/login"><a >Log in!</a></Link>
}
return null
}
}, comparator);
【问题讨论】:
-
我不确定useEffect中的返回true/false是否与组件渲染有关。因为,如果我们在 useEffect 中返回一个函数,它将作为清理函数运行,但是,我认为它与布尔值无关。
-
另外,我不确定 nextProps 是否在 useEffect 中可用。所以,我会把它留给更好的人来澄清
-
为什么首先需要“setProps”状态和这些检查?您永远不会在渲染阶段使用该状态,并且您 useEffect 没有任何用处。如果您只留下
if (isLoggedIn) { ... }部分会出现什么问题?
标签: reactjs state react-hooks high-order-component react-lifecycle-hooks