[Functional Programming ADT] Initialize Redux Application State Using The State ADT
Not only will we need to give our initial state to a Redux store, we will also need to be able to reset our state at any time by dispatching an action. We can get the best of both worlds by having a function that will return an object with all of our initial values in it. Then use that function to craft a State
ADT transition that will throw out whatever our previous state was and replace it with the original initial state.
We’ll not only build out an initialize state transaction, but also use that new transaction to craft an action creator to expose a means to dispatch at any time an action that will reset our state.
Set initial state:
We use PUT state to reset the state.
import State from "crocks/State"; const { put } = State; // initialState :: () -> AppState export const initialState = () => ({ colors: ["orange", "green", "blue", "yellow"], shapes: ["triangle", "circle", "square"], cards: [], hint: {}, isCorrect: null, left: 8, moves: 0, rank: 4, seed: 23 }); // initialize :: () -> State AppState () const initialize = () => put(initialState()); export default initialize;
Create action for reducer:
1. Create action const string
2. Action creator
3. Create reducer, bind action const to state ()
import { createAction, createReducer } from "../helpers"; import start, { markCardsUnselected } from "../model/game"; import initialize from "../model/initialize"; const HIDE_ALL_CARDS = "HIDE_ALL_CARDS"; const START_GAME = "START_GAME"; const RESET_GAME = "RESET_GAME"; // hideAllCards :: String -> Action String export const hideAllCards = createAction(HIDE_ALL_CARDS); // startGame :: String -> Action String export const startGame = createAction(START_GAME); // startGame :: String -> Action String export const resetGame = createAction(RESET_GAME); // reducer :: Reducer const reducer = createReducer({ HIDE_ALL_CARDS: markCardsUnselected, START_GAME: start, RESET_GAME: initialize }); export default reducer;
Kick off:
Call the reducer with state, action.
import log from "./logger"; import reducer from "./data/reducers"; import { resetGame } from "./data/reducers/game"; import initialize from "./data/model/initialize"; log(reducer({}, resetGame()));
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2018-02-08 [ReactVR] Render Custom 3D Objects Using the Model Component in React VR
2018-02-08 [ReactVR] Add Lighting Using Light Components in React VR
2018-02-08 [ReactVR] Add Shapes Using 3D Primitives in React VR
2017-02-08 [NPM] Add comments to your npm scripts
2017-02-08 [NPM] List available npm scripts and support tab completion
2017-02-08 [NPM] Make npm scripts cross-environment friendly
2017-02-08 [Ramda] Count Words in a String with Ramda's countBy and invert