react 自定义状态管理库

核心实现原理 :
全局状态容器:维护单一状态源
订阅机制:组件订阅状态变化
状态更新调度:通过 Hooks 触发组件重渲染

基础版实现--核心代码
javascript 复制代码
// 1. 创建全局状态存储
const createStore = (initialState) => {
  let state = initialState
  const listeners = new Set()

  return {
    getState: () => state,
    setState: (newState) => {
      state = typeof newState === 'function' ? newState(state) : newState
      listeners.forEach(listener => listener()) // 通知所有订阅者
    },
    subscribe: (listener) => {
      listeners.add(listener)
      return () => listeners.delete(listener) // 返回取消订阅函数
    }
  }
}

// 2. 创建 React Hook 绑定
const useStore = (store, selector) => {
  const [state, setState] = useState(() => selector(store.getState()))

  useEffect(() => {
    const unsubscribe = store.subscribe(() => {
      const newState = selector(store.getState())
      setState(newState) // 只有当选中的状态变化时才更新
    })
    return unsubscribe
  }, [store, selector])

  return state
}

使用示例

javascript 复制代码
// 创建 store
const counterStore = createStore({ count: 0 })

// 在组件中使用
const Counter = () => {
  const count = useStore(counterStore, state => state.count)
  
  return (
    <div>
      <button onClick={() => counterStore.setState(s => ({ count: s.count - 1 }))}>
        -
      </button>
      <span>{count}</span>
      <button onClick={() => counterStore.setState(s => ({ count: s.count + 1 }))}>
        +
      </button>
    </div>
  )
}
相关推荐
ZFSS13 小时前
Midjourney Shorten API 的集成与使用
java·前端·数据库·人工智能·ai·midjourney·ai编程
Pu_Nine_913 小时前
IntersectionObserver 详解:封装 Vue 指令实现图片懒加载
前端·javascript·vue.js·性能优化
清灵xmf13 小时前
Web 和 Native 是怎么“对话“的?JSBridge 解答
前端·webview·native·jsbridge·hybrid
jiayong2314 小时前
前端面试题库 - ES6+新特性篇
前端·面试·es6
前端那点事14 小时前
Vue nextTick 超全解析|作用、使用场景、底层原理、Vue2/Vue3区别
前端·vue.js
前端那点事14 小时前
Vue面试高频:子组件能直接修改父组件数据吗?单向数据流原理+正确写法全覆盖
前端·vue.js
前端那点事14 小时前
为什么 Vue 的 template 标签不能用 v-show?底层机制+踩坑复盘+生产级解决方案
前端·vue.js
weelinking15 小时前
【claude】14_Claude作为技术文档助手
前端·人工智能·react.js·数据挖掘·前端框架
jiayong2315 小时前
前端面试题库 - JavaScript核心基础篇
前端·javascript·面试
软件技术NINI15 小时前
泉州html+css 4页
前端·javascript·css·html