[英]Ternary Operator - Is there a possible bug in React's conditional rendering?
目前,我正在使用 Node.js 和 React 进行开发,遇到了一个奇怪的问题,我不确定我是否遗漏了某些东西,或者它是否是 React 方面的错误。
我想要做的是使用三元运算符来呈现条件 HTML ,如下所示:
...
{
missingTradingSystemNameError
?
<div>
...
</div>
:
duplicateTradingSystemNameError
?
<div>
...
</div>
:
null
}
...
在我的 JSX.Element function 中,这两个三元运算符条件都是有状态变量。 但是,这样做会导致以下形式的多个错误:
错误:
React Hook "React.useEffect" is called conditionally. React Hooks must be called in the exact same order in every component render
有趣的是,如果我添加第三个(无用的)嵌套条件代替null ,那么一切都按预期工作:
...
{
missingTradingSystemNameError
?
<div>
...
</div>
:
duplicateTradingSystemNameError
?
<div>
...
</div>
:
<<condition3>>
?
null
:
null
}
...
condition3是第三个有状态变量,但正如您所见,附加条件什么也不做,因此应该可以省略它。 这是一个 React 错误还是我在这里遗漏了一些重要的东西?
(PS:请原谅我的代码不寻常的缩进,但对我来说,这是目前更复杂的 JSX 代码块最易读的解决方案)
编辑1:
为了提供一些进一步要求的细节,这里是我简化的 useEffect() 代码块:
const [missingTradingSystemNameError, setMissingTradingSystemNameError] = React.useState(false);
const [duplicateTradingSystemNameError, setDuplicateTradingSystemNameError] = React.useState(false);
...
React.useEffect(() => {
if (props.tradingSystemDialog && resetTradingSystemDialogOnNextOpen) {
...
setMissingTradingSystemNameError(false);
setDuplicateTradingSystemNameError(false);
...
}
}, [
props.tradingSystemDialog,
resetTradingSystemDialogOnNextOpen,
tickFields,
consolidatedFields
]);
missingTradingSystemNameError是通过setMissingTradingSystemNameError设置的,而duplicateTradingSystemNameError是通过setDuplicateTradingSystemNameError设置的。 如您所见,这些有状态变量可能在 useState() 中被更改,但它们不在 useState() 的依赖项中。
提供一个最小的可重现示例是最好的,但在我的情况下上下文太复杂了。 但是,我所做的是删除越来越多的代码来检查是否是一小部分导致了问题。 现在我得出的结论是,文件中其他位置的以下代码片段存在问题,并导致上述代码失败或至少以奇怪的方式运行:
...
{
basicShortSettingsError
?
<div className={classes.error}>
<ErrorOutline
className={classes.errorIcon}
/>
<Typography className={classes.sectionError} variant="body2">
{
parseFloat(positionSizeShort) > parseFloat(maxContractsShort)
?
"Position size > maximum contracts"
:
"Set position size and maximum contracts"
}
</Typography>
</div>
:
null
}
...
出于某种原因, Typography标记内的条件部分以前有效,但现在如果我通过我在问题中提到的内容在文件中的某个其他点扩展代码,则会导致错误。
为了澄清,这是导致问题的代码片段:
<Typography className={classes.sectionError} variant="body2">
{
parseFloat(positionSizeShort) > parseFloat(maxContractsShort)
?
"Position size > maximum contracts"
:
"Set position size and maximum contracts"
}
</Typography>
positionSizeShort和maxContractsShort也是有状态的变量,我不确定为什么代码之前工作得很好,现在却失败了,但至少我现在找到了问题的根源,我可能可以在其中解决问题。
如果有人对为什么这段代码有问题有更好的了解,那么非常欢迎在这里分享您的想法,因为我对我的问题没有真正的答案。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.