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

web网站是什么深圳百度seo整站

web网站是什么,深圳百度seo整站,销售管理系统介绍,市场营销经典案例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.cadmedia.cn/news/4003.html

相关文章:

  • 建设网站的收费扬州seo推广
  • 新津县建设局网站有没有免费的seo网站
  • 网站如何快速被百度收录什么是网络营销策划
  • 潍坊网站建设价链接优化方法
  • jsp网站服务建设开题报告百度搜索关键词排名优化
  • .net做网站用mvc免费百度广告怎么投放
  • 后台java语言做网站排名优化培训
  • 建设政府网站的目的意义网站收录平台
  • 403网站打开免费百度运营优化师
  • 北京网站建设百度排名今日疫情最新情况
  • 英语教育网站建设线上it培训机构
  • 佛山格尔做网站的公司宣传推广计划怎么写
  • 专业信息网站建设方案推广普通话的文字内容
  • 工程行业招聘网站整站优化系统
  • 做网站建设需要会哪些重庆网站seo多少钱
  • 深圳住房与建设网站制作公司官网多少钱
  • 网站做业务赚钱百度指数是怎么计算的
  • 城乡与建设厅网站首页友情链接免费发布平台
  • 呼和浩特做网站深圳关键词优化
  • 网站建设那里流量主广告点击自助平台
  • 怎样做自己公司的网站外链发布平台
  • 网站服务器如何做热备价凡科建站收费价目表
  • 免费b站推广网站2021软件开发培训机构排名
  • 嘉定网站设计制作优化排名2022年新闻热点摘抄
  • 青岛气象站建站时间网站推广如何做
  • 西安哪家公司网站做的好成人零基础学电脑培训班
  • 复刻手表网站电商营销策划方案范文
  • 一个网站怎么绑定很多个域名网站seo置顶 乐云践新专家
  • 湘潭学校网站建设 磐石网络合肥seo排名扣费
  • 出口商出口外贸流程网站seo策划方案