当前位置: 首页 > news >正文

网站建设推广浩森宇特网站创建流程

网站建设推广浩森宇特,网站创建流程,国内vps推荐,搭建平台网站有什么用Redux是React中使用较多的状态管理库,这篇文章主要介绍了Redux的基本用法,快来看看吧 首先我们需要新建一个React项目,我使用的ReactTS,文件结构如下 Redux的相关使用主要在store文件中 Store:存储整个应用的状态Act…

Redux是React中使用较多的状态管理库,这篇文章主要介绍了Redux的基本用法,快来看看吧
首先我们需要新建一个React项目,我使用的React+TS,文件结构如下
在这里插入图片描述
Redux的相关使用主要在store文件中

  1. Store:存储整个应用的状态
  2. Action:一个描述发生了什么的JS对象
  3. Reducer:一个纯函数,根据传入的action更新相关的状态
  4. Dispatch:发送action到reducer的方法
  5. Selector:从Store中获取函数的函数

接下来,需要安装相关的包

npm install redux react-redux

之后,我们在相关文件中写相关的规范

  1. types.ts
export const INCREMENT = 'INCREMENT';
export const DECREMENT = 'DECREMENT';
  1. action.ts
import { INCREMENT, DECREMENT } from './types';export const increment = () => ({type: INCREMENT,
});export const decrement = () => ({type: DECREMENT,
});
  1. reducers.ts
import { INCREMENT, DECREMENT } from './types';const initialState = {count: 0,
};const counterReducer = (state = initialState, action) => {switch (action.type) {case INCREMENT:return { ...state, count: state.count + 1 };case DECREMENT:return { ...state, count: state.count - 1 };default:return state;}
};export default counterReducer;
  1. index.js
import { createStore } from 'redux';
import { composeWithDevTools } from 'redux-devtools-extension';
import counterReducer from './reducers';const store = createStore(counterReducer, composeWithDevTools());export default store;

之后,我们需要将store提供给React应用来使用,在main.tsx中,进行如下修改

// import { StrictMode } from 'react'
import { createRoot } from 'react-dom/client'
import App from './App.tsx'
import './index.css'
import store from './store/index.ts'
import { Provider } from 'react-redux'createRoot(document.getElementById('root')!).render(// <StrictMode><Provider store={store}><App /></Provider>// </StrictMode>,
)

这样做的目的是,将 Redux Store 注入到整个 React 应用中,这样子组件都可以通过 useSelector 和 useDispatch 访问 Store

接下来,就是在组件中进行使用了,在我们的App.tsx文件中,将相关的方法进行引用

import './App.css'
import { useSelector, useDispatch } from 'react-redux';
import { increment, decrement } from './store/action';function App() {// 使用 useSelector 从 Redux Store 获取数据const count = useSelector((state) => state.count);// 使用 useDispatch 发送 actionconst dispatch = useDispatch();return (<><div><h2>Count: {count}</h2><button onClick={() => dispatch(increment())}>Increment</button><button onClick={() => dispatch(decrement())}>Decrement</button></div></>)
}export default App

useSelector() 可以从 Store 中选择数据,然后调用useDispatch() 返回 dispatch 方法,可以触发相关的action,这样就可以成功使用Redux了

但是,在实际开发中,我们大多数情况下都是会处理异步的情况,那么在Redux中如何使用异步呢?由于Redux本身只支持同步数据流,如果处理异步操作,我们需要使用React Thunk中间件
首先需要在store文件夹下边index.ts文件中进行如下修改

import { createStore, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';
import { composeWithDevTools } from 'redux-devtools-extension';
import counterReducer from './reducers';const store = createStore(counterReducer,composeWithDevTools(applyMiddleware(thunk))
);export default store;

接下来就可以在action.ts文件中封装相关的异步操作,案例如下

export const fetchData = () => {return async (dispatch) => {try {const response = await fetch('www.baidu.com');const res = await response.json();dispatch({ type: 'FETCH_SUCCESS', payload: data });} catch (error) {dispatch({ type: 'FETCH_ERROR', payload: error });}};
};

最后在reducers.ts中进行数据返回即可

const initialState = {count: 0,data: null,error: null,
};const counterReducer = (state = initialState, action) => {switch (action.type) {case 'FETCH_SUCCESS':return { ...state, data: action.payload };case 'FETCH_ERROR':return { ...state, error: action.payload };default:return state;}
};export default counterReducer;

以上便是Redux的基本操作,希望可以帮助到你

http://www.dt0577.cn/news/36542.html

相关文章:

  • 全网营销型网站百度关键词排名神器
  • 手机怎么做电子书下载网站百度平台商户电话号码
  • 湖南省网站备案自己搭建网站
  • 建设电影网站难吗网站404页面怎么做
  • 用python做网站多吗最优化方法
  • 深圳有做网站的公司百度营消 营销推广
  • wordpress广告链接不跳转超级推荐的关键词怎么优化
  • 网站套站什么意思自己怎么优化关键词
  • h5app开发教程站内关键词自然排名优化
  • 九台网站手机端怎么刷排名
  • 淄博网站建设多杭州龙席网络seo
  • 乌鲁木齐建设局官方网站汕头网站设计公司
  • 做竞价网站 要注意什么如何建网站
  • 广州网站空间2024年阳性什么症状
  • 做网站镜像微信上如何投放广告
  • 佛山网站推广市场app推广代理平台
  • 网站正在建设中超级优化大师下载
  • 江苏住房和城乡建设部网站班级优化大师头像
  • 选择做网站销售的优势seo官网
  • 网站搭建是什么专业游戏推广员每天做什么
  • 广告设计公司深圳品牌设计公司百度关键词优化查询
  • 网店erpseo快速排名是什么
  • 网站怎么做充值系统下载怎么建网站平台卖东西
  • 搭建网站需要学什么软件四川旅游seo整站优化
  • 交换广告是两个网站做友情链接吗搜索量排行
  • 用xp做网站是否先搭建iis重庆放心seo整站优化
  • 做微商哪个网站比较好nba最新交易信息
  • wordpress开发视频网站ip反查域名网站
  • 网站链接数百度点击器找名风软件
  • 佛山顺德网站建设公司前端培训哪个机构靠谱