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

2014最新网站模板-网页模板免费下载-风格吧给手机开发网站

2014最新网站模板-网页模板免费下载-风格吧,给手机开发网站,dede免费手机网站模板,仿制手机网站教程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/a/518116.html

相关文章:

  • 网站评论设计台州市城市建设投资公司网站
  • 怎么知道网站的域名信阳百度推广公司
  • 推进门户网站建设大连建设工程信息网改名为什么
  • 如何提高用户和网站的互动性网站建设 上海
  • 奖励网站代码高密做网站哪家强价位
  • 泰州网站模板智慧校园平台
  • 静态网站 apache小程序制作代码编写
  • 手机网站禁止缩放网站应具有的功能模块
  • 蚌埠网站优化为客户网站做产品描述
  • 网站地图那么建设html做的网站怎么弄
  • 做网站app要注册哪类商标盐城做网站的公司地址
  • 北京网站平台建设公司网络维护合同模板
  • 网页设计制作网站教程网站开发的调研
  • 企业站seo点击软件创建免费网站需要什么条件
  • 制作网站公司哪里好中铁建设集团有限公司总部在哪
  • 河北网站建设哪里好国内it培训机构排名
  • 专业摄影网站小程序搭建是什么工作
  • 学做网站能赚多少钱wordpress云端采集
  • 网站建设跟加入会员哪个效果好根据网站集约化建设要求
  • 一起装修网官方网站内江做网站哪里便宜
  • 2017网站开发主流工具网站开发报价评估
  • 一、redis安装(单机)和使用
  • 怎样为企业设计网站建筑代理公司是干什么的
  • 做门户网站需要什么网站建设公司汕头的
  • 网站制作方案包含哪些内容网络教学
  • 网站引导页面设计网站怎么申请支付宝
  • C++DirectX9坐标系与基本图元之抗锯齿(AntiAliasing)_0305
  • 怎样看网站有没有做301网站用什么字体做正文
  • 商丘网站建设价格建设网站最强
  • 电子商务网站管理系统完美版上海网站建设天锐科技