我正在尝试从 to 移植class component
到react hooks
with Context API
,但我无法弄清楚出现错误的具体原因是什么。
首先,我的代码:
// contexts/sample.jsx
import React, { createContext, useState, useContext } from 'react'
const SampleCtx = createContext()
const SampleProvider = (props) => {
const [ value, setValue ] = useState('Default Value')
const sampleContext = { value, setValue }
return (
<SampleCtx.Provider value={sampleContext}>
{props.children}
</SampleCtx.Provider>
)
}
const useSample = (WrappedComponent) => {
const sampleCtx = useContext(SampleCtx)
return (
<SampleProvider>
<WrappedComponent
value={sampleCtx.value}
setValue={sampleCtx.setValue} />
</SampleProvider>
)
}
export {
useSample
}
// Sends.jsx
import React, { Component, useState, useEffect } from 'react'
import { useSample } from '../contexts/sample.jsx'
const Sends = (props) => {
const [input, setInput ] = useState('')
const handleChange = (e) => {
setInput(e.target.value)
}
const handleSubmit = (e) => {
e.preventDefault()
props.setValue(input)
}
useEffect(() => {
setInput(props.value)
}, props.value)
return (
<form onSubmit={handleSubmit}>
<input value={input} onChange={handleChange} />
<button type="submit">Submit</button>
</form>
)
}
我得到的错误:
不变违规:无效的钩子调用。钩子只能在函数组件的主体内部调用。这可能是由于以下原因之一而发生的: 1. 你可能有不匹配的 React 版本和渲染器(例如 React DOM) 2. 你可能违反了 Hooks 规则 3. 你可能有多个 React 副本同一个应用程序 请参阅https://reactjs.org/warnings/invalid-hook-call-warning.html有关如何调试和解决此问题的提示。
我的代码的解释:
我Context API
以前管理状态,以前我用class component
s 来制作视图。我希望结构简单明了,不需要更多细节。
我认为它也应该可以工作,<Sends />
组件被传递到useSample
HoC 函数中,并且它被<SampleProvider>
组件包裹起来sample.jsx
,以便<Sends />
可以使用上下文props
提供的SampleCtx
。但结果是失败。
将HoC
模式与一起使用是否无效React hooks
?或者通过 将变异函数(即setValue
由useState()
)传递给其他组件是否无效props
?或者,在单个文件中放置 2 个或多个function components
using是否无效hooks
?请指正具体原因是什么。