Redux 是一个 React 应用的状态管理库,它能够让前端开发者更好地管理应用程序中的数据。而 TypeScript 则是 JavaScript 的一种超集,它提供了静态类型检查和其他语言特性,并且可以让我们在编写代码时更加安全和舒适。在这篇文章中,我们将探讨如何在 TypeScript 中使用 Redux 以及注意事项。
安装 Redux 和 TypeScript 相关的库
在使用 Redux 之前,我们需要先安装 Redux 本身和一些 TypeScript 相关的库,这些库能够帮助我们正确地使用 TypeScript 和 Redux。
npm install redux react-redux @types/react-redux redux-thunk @types/redux-thunk
redux
是 Redux 库本身,react-redux
是将 Redux 库与 React 结合使用的库, @types/react-redux
是 React Redux 库的 TypeScript 类型定义,redux-thunk
是一个让我们可以在 Redux 中写异步逻辑的库,@types/redux-thunk
是 redux-thunk
的 TypeScript 类型定义。
创建 Redux store
Redux 应用程序的核心是 Redux store,store 保存了我们应用程序的状态(state)。 在 TypeScript 中创建 Redux store 的过程与 JavaScript 中的过程非常相似。
import { createStore, applyMiddleware } from 'redux'; import thunk from 'redux-thunk'; import rootReducer from './reducers'; const store = createStore(rootReducer, applyMiddleware(thunk));
在代码中,我们首先导入了 createStore
和 applyMiddleware
函数,然后通过 createStore
函数和 rootReducer
参数创建了 Redux store,applyMiddleware
函数包裹了 thunk
中间件,使得我们可以在 Redux 中进行异步操作。
定义 Redux 状态(state)
在 Redux 中,应用程序的状态(state)是一个普通的 JavaScript 对象,我们可以根据我们的应用程序需要定义一个状态。
interface AppState { count: number } const initialState: AppState = { count: 0, }
在代码中,我们首先定义了一个 TypeScript 接口 AppState,它描述了我们应用程序状态的结构,我们只需要在接口中定义我们的状态数据类型即可。 然后,我们定义了一个初始状态 initialState
,它包含了我们的状态数据。
-- -------------------- ---- ------- -------- -------------------- - ------------- ------- - ------ ------------- - ---- ------------ ------ - ------ ----------- - - -- ---- ------------ ------ - ------ ----------- - - -- -------- ------ ------ - -展开代码
接下来,我们需要编写一个 Redux reducer 函数,它接收当前状态和一个动作(action),并返回一个新的状态。在代码中,我们定义了一个简单的 counterReducer 函数,它接收当前状态(state)和一个 action 对象, 根据 action.type 的值更新我们的状态(state)。
连接 React 应用和 Redux 应用
在 TypeScript 和 React 应用中,我们需要通过 Provider
组件来连接我们的 Redux 应用和我们的 React 应用。
-- -------------------- ---- ------- ------ - -------- - ---- -------------- ------ --- ---- ------------------- ---------------- --------- -------------- ---- -- ------------ ------------------------------- --展开代码
在实例代码中,我们通过 Provider
组件提供了 store 属性,然后将 <App />
组件作为子组件传递给 Provider
组件。 这样,我们就可以在整个 React 应用程序中访问 Redux store 了。
在 TypeScript 中定义 Action
Redux 中的 Action 是一个 Plain Object
,它描述了在应用程序中发生的事件。我们可以在 TypeScript 中定义好我们的 Action,并且增强类型的检查。
-- -------------------- ---- ------- --------- --------------- - ----- ------------ - --------- --------------- - ----- ------------ - ---- ------------- - --------------- - ----------------展开代码
在代码中,我们首先定义了 IncrementAction
和 DecrementAction
两个 TypeScript 接口,它们都描述了一个 type
字段以及它们各自的其他字段。然后,我们定义了一个 CounterAction
类型,它是 IncrementAction
和 DecrementAction
的联合类型,并且可以用于我们的 reducer 函数。
使用 TypeScript 编写 thunk
在 Redux 中,我们可以使用中间件(thunk)来执行异步操作,比如调用 API。在 TypeScript 中,我们可以使用一个基于接口的 thunk 来更好地描述我们的异步操作。
interface ThunkAction<R, S, E, A extends Action> { (dispatch: Dispatch<A>, getState: () => S, extraArgument: E): R; }
在代码中,我们定义了一个名为 ThunkAction
的接口,它描述了 Thunk 的结构, 我们可以使用此接口来标记我们的 Thunk。
import { ThunkAction } from 'redux-thunk'; import { Action } from 'redux'; import { AppState } from '../reducers'; export const incrementCounter: ThunkAction<void, AppState, {}, Action> = () => (dispatch, getState) => { dispatch({ type: 'INCREMENT' }); };
在示例代码中,我们首先导入了 ThunkAction
接口,以及一些用于类型检查的库。然后,我们定义了一个名为 incrementCounter
的 thunk 函数,它接收并返回一个 thunk, 我们可以使用此函数来分发一个 INCREMENT
操作并更改我们的状态(state)。
注意事项
使用 Typings
在使用 TypeScript 和 Redux 时,我们需要确保我们安装了正确的类型库, 如 @types/react-redux
和 @types/redux-thunk
,这样 TypeScript 就可以正确地检测我们代码中的类型。
推断状态类型
在 TypeScript 中,我们希望尽可能多地推断变量的类型,特别是在我们的 Redux 应用程序中,在定义我们的状态时,我们可以尽可能多地使用 TypeScript 接口。
推断动作类型
在 TypeScript 中,我们也希望尽可能多地推断我们的Redux Action类型。 我们可以在定义的 Action 中增加 Payload
属性来更好地描述 Action。
结论
在 TypeScript 中使用 Redux 可以让我们更好的组织和管理我们的应用程序状态,并在编写代码时提供一层额外的保护。 在这篇文章中,我们介绍了如何在 TypeScript 中使用 Redux,并且探讨了一些注意事项。希望这篇文章对于您在 TypeScript 中使用 Redux 提供了帮助和指导。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/66fb4d1744713626015b14df