[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()));
复制代码

 

posted @   Zhentiw  阅读(198)  评论(0编辑  收藏  举报
编辑推荐:
· 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
点击右上角即可分享
微信分享提示