javascript - 如何实现具有动态状态数的 Context API?
问题描述
数组中的组件数量listOfComponents
应该是动态的。在我的应用程序中,组件在应用程序运行时会随着时间的推移而添加和删除。当我添加一个新组件时,我想listOfComponents
在我的ExampleContext
. 当我删除一个组件时,我想删除状态。listOfComponents
只有在 id 匹配的地方更新了设置,组件才应该重新渲染。我将如何实施呢?
import React, { createContext, useState } from 'react'
export const ExampleContext = createContext()
export const { Consumer: ExampleConsumer } = ExampleContext
export function ExampleProvider({ children }) {
const [state, setState] = useState({
listOfComponents: [{
id: 1,
settings: {color: 'red'}
},
{
id: 2,
settings: {color: 'blue'}
},
{
id: 3,
settings: {color: 'green'}
}]
})
return (
<ExampleContext.Provider value={[state, setState]}>
{children}
</ExampleContext.Provider>
)
}
export function Component({id}) {
const [state, setState] = useContext(ExampleContext)
return (
<h1> Only rerender me if settings of matching id are updated! </h1>
)
}
解决方案
这是我如何使它与useMemo
. 也许它对其他人有帮助,因为我花了一些时间才弄清楚。这篇博文也很有帮助。如果有更好的方法请告诉我。
-- 应用程序.js
import React, {useContext, useMemo} from 'react';
import {ExampleContext, ExampleProvider} from './Context'
export function Component({id}){
const [state, setState] = useContext(ExampleContext)
function onClick(){
setState(prev => {
return {...prev, [id]: { color: 'blue'}}
})
}
return useMemo(() => {
console.log(`update ${id}`)
return (
<>
<h1 style={{color: state[id].color}}>{id}</h1>
<button onClick={onClick}>{`Update from ${id}`}</button>
</>
)
}, [state[id]])
}
function App() {
return (
<ExampleProvider>
<Component id={1}/>
<Component id={2}/>
</ExampleProvider>
);
}
export default App;
-- 上下文.js
import React, { createContext, useState } from 'react'
export const ExampleContext = createContext()
export const { Consumer: ExampleConsumer } = ExampleContext
export function ExampleProvider({ children }) {
const [state, setState] = useState({
'1': {color: 'red'},
'2': {color: 'green'},
})
return (
<ExampleContext.Provider value={[state, setState]}>
{children}
</ExampleContext.Provider>
)
}
推荐阅读
- python - 不能使用 pandas,TypeError: 'int' object is not subscriptable
- javascript - 如何使方法返回静态属性中“保存”的类型?
- php - 为 PHP 查询创建准备好的语句
- reactjs - 如何在jsx中使用包含冒号的属性名称
- css - 在 CSS 代码中用 ':is()' 替换每个 ':-moz-any()' 伪类有什么问题吗?
- r - 滚动比较以创建新列
- mysql - MySQL 中的 SELECT 不起作用
- c++ - 如何从一个类中调用一个函数并将其应用于 C++ 中不同类的另一个函数?
- tabs - 我如何在 CefSharp 中使用 EasyTabs 重命名功能
- f# - 将数组分成块 F#