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

人力资源网站建设软文推广网站

人力资源网站建设,软文推广网站,中央党建网站党建文化建设点,b2c模式的网站Redux与计数器 配套工具使用React Toolkit 创建 counterStore为React注入storeReact组件使用store中的数据React组件修改store中的数据绑定用户交互效果展示action传参Redux异步状态管理 React中的Redux就像Vue中的Vuex和Pinia一样,都是状态管理工具,通过…

Redux与计数器

  • 配套工具
  • 使用React Toolkit 创建 counterStore
  • 为React注入store
  • React组件使用store中的数据
  • React组件修改store中的数据
  • 绑定用户交互
  • 效果展示
  • action传参
  • Redux异步状态管理

  • React中的Redux就像Vue中的Vuex和Pinia一样,都是状态管理工具,通过这种方式可以很方便的实现各个组件中的通信。
  • 下面的代码是通过Redux实现一个计数器

配套工具

  • 在React中使用Redux,官方要求安装两个插件:Redux Toolkitreact-redux

使用React Toolkit 创建 counterStore

import { createSlice } from "@reduxjs/toolkit";const counterStore = createSlice({//name属性不可少,否则会报错name:'counter',//初始化stateinitialState:{count:0},//修改状态的方法 可以直接修改reducers:{//点击加号increment(state){state.count++},//点击减号decrement(state){state.count--}}
})
//解构函数
const {increment,decrement} = counterStore.actions
//获取reducer
const reducer = counterStore.reducer
//按需导出函数
export {increment,decrement}
//默认导出方式导出reducer
export default reducer

为React注入store

  • react-redux负责把Redux和React连接起来,内置Provider组件通过store参数把创建好的store实例注入到应用中,连接正式建立
import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';
import store from './store';
import { Provider } from 'react-redux';//把APP根组件渲染到id位root的dom节点上
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<React.StrictMode><Provider store={store}><App /></Provider></React.StrictMode>
);

React组件使用store中的数据

  • 在React组件中使用store中的数据,需要用到一个钩子函数useSelector,它的作用是把store中的数据映射到组件中
    const {count} = useSelector(state=>state.counter)

React组件修改store中的数据

  • React组件中修改store中的数据需要借助另外一个hook函数 - useDispatch,它的作用是生成提交action对象的dispatch函数
    action传参
  • 在reducers的同步修改方法中添加action对象参数,在调用actionCreater的时候传递参数,参数会被传递到action对象payload属性上
    Redux异步状态管理
  • 步骤:
    • 创建store的写法保持不变,配置好同步修改状态的方法
    • 单独封装一个函数,在函数内部return一个新函数,在新函数中:
      • 封装异步请求获取数据
      • 调用同步actionCreater传入异步数据生成一个action对象,并使用dispatch提交
    • 组件中dispatch的写法保持不变

绑定用户交互

  • 获取状态:通过useSelector,组件从Redux store中获取count状态。这里的state.counter假设是store中的一个对象,其中包含count属性。
  • 获取dispatch函数:通过useDispatch,组件获取到dispatch函数,这个函数用于将action发送到Redux store。
  • 渲染UI:组件渲染两个按钮和当前的count值。点击按钮时,会触发相应的action(increment或decrement),通过dispatch函数发送到Redux store,从而更新状态。
import { useSelector,useDispatch } from "react-redux";
//导入actionCreator
import { increment,decrement,addToNum } from "./store/modules/counterStore";
const App = () => {const {count} = useSelector(state=>state.counter)// const {channelList} = useSelector(state=>state.channel)const dispatch = useDispatch()return (<div><button onClick={()=>dispatch(decrement())}>-</button>{count}<button onClick={()=>dispatch(increment())}>+</button></div>  );
};export default App;

效果展示

在这里插入图片描述

action传参

  • 在reducers的同步修改方法中添加action对象参数,在调用actionCreater的时候传递参数,参数会被传递到action对象payload属性上

Redux异步状态管理

  • 步骤:
    • 创建store的写法保持不变,配置好同步修改状态的方法
    • 单独封装一个函数,在函数内部return一个新函数,在新函数中:
      • 封装异步请求获取数据
      • 调用同步actionCreater传入异步数据生成一个action对象,并使用dispatch提交
    • 组件中dispatch的写法保持不变
http://www.dtcms.com/wzjs/6191.html

相关文章:

  • 影视网站怎么做免费做网站的平台
  • 做钟点工 网站兰州网络推广推广机构
  • 企业网站 报价站长工具
  • 合肥网站建设制作搜索网络如何制造
  • seo做的比较好的网站为什么中国禁止谷歌浏览器
  • 套b网站关键信息基础设施安全保护条例
  • 网站如何做竟价南京网络建站公司
  • 个人帮企业做网站高端企业网站模板
  • 深圳企业推广网站廊坊优化技巧
  • 四川省建设安全协会网站企业网络推广平台
  • 对政府网站建设的建议网络工程师培训机构排名
  • 娄底网站建设工作室推广软文是什么意思
  • 怎么做时时彩彩票网站在哪里推广自己的产品
  • 想给公司做网站中企动力靠谱吗企业网络策划
  • 网站的跳出率很高灰色关键词代发可测试
  • 嘉定专业做网站seoul是什么国家
  • 爱网站排行榜娄底地seo
  • 网站建设和seo讲师要求上海网站seoseodian
  • 网站服务器建设方案seo课程多少钱
  • 杭州海淀区网站建设赣州seo外包怎么收费
  • 网站推广目标是什么长春网站优化团队
  • 泰安商城网站开发设计短视频代运营方案策划书
  • 郑州网站网站建设网络推广营销网站建设专家
  • 提高网站关键词排名策划方案模板
  • 上海营销型网站代理南昌企业网站建设
  • 西安三桥网站建设百度代理公司
  • 许昌优化公司福州seo顾问
  • 网站滚动图片效果怎么做网络站点推广的方法
  • 南京网站设计搭建公司seo推广培训资料
  • 自做装逼头像网站口红的推广软文