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>
  )
}
相关推荐
雪碧聊技术2 小时前
前端项目代码发生改变,如何重新部署到linux服务器?
前端·vue3·centos7·代码更新,重新部署
liulilittle3 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
wordbaby3 小时前
Expo 进阶指南:赋予 TanStack Query “原生感知力” —— 深度解析 AppState 与 NetInfo
前端·react native
Moment3 小时前
从美团全栈化看 AI 冲击:前端转全栈,是自救还是必然 🤔🤔🤔
前端·后端·面试
天问一3 小时前
使用 Vue Router 进行路由定制和调用的示例
前端·javascript·vue.js
韩立学长5 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js
优弧5 小时前
离开舒适区100天,我后悔了吗?
前端·后端·面试
胡gh5 小时前
css的臂膀,前端动效的利器,还是布局的“隐形陷阱”?
前端·css·html
灵感菇_5 小时前
Flutter Riverpod 完整教程:从入门到实战
前端·flutter·ui·状态管理
用户21411832636025 小时前
紧急修复!Dify CVE-2025-55182 高危漏洞,手把手教你升级避坑
前端