react學習——25redux實現求和案例(完整版)

1、目錄結構
在這里插入圖片描述
2、count/index.js

import React, {Component} from "react";
//引入store,用于獲取數據
import store from '../../redux/store'
//引入actionCreator 專門創建action對象
import {createDecrementAction,createIncrementAction} from '../../redux/count_action'export default class Count extends Component {state = {count:store.getState()}componentDidMount() {//監測redux中的數據的變化,只要改變,就會調用renderstore.subscribe(()=>{this.setState({count:store.getState()})})}//加法increment=()=>{const {value} = this.selectNum//通知redux 改變// store.dispatch({type:'increment',data:parseInt(value)})store.dispatch(createIncrementAction(parseInt(value)))}//減法decrement=()=>{const {value} = this.selectNumstore.dispatch(createDecrementAction(parseInt(value)))}//奇數加incrementIfOdd=()=>{const {value} = this.selectNumconst {count} = this.stateif(count%2!==0){store.dispatch(createIncrementAction(parseInt(value)))}}//異步加incrementAsync=()=>{const {value} = this.selectNumsetTimeout(()=>{store.dispatch(createIncrementAction(parseInt(value)))},500)}render(){return(<div><h1>當前求和為:{store.getState()}</h1><select ref={(c)=>this.selectNum=c}><option value="1">1</option><option value="2">2</option><option value='3'>3</option></select>&nbsp;<button onClick={this.increment}>+</button>&nbsp;<button onClick={this.decrement}>-</button>&nbsp;<button onClick={this.incrementIfOdd}>當前求和為奇數在加</button>&nbsp;<button onClick={this.incrementAsync}>異步加</button>&nbsp;</div>);}}

2、redux/constant.js

/*該模塊用于定義狀態管理的常量名稱,目的只有一個:便于管理的同時,防止程序員單詞拼寫錯誤
*/
export const INCREMENT = 'increment'
export const DECREMENT = 'decrement'

redux/count_action.js

/*該文件專門為Count組件生成action對象*/
import {INCREMENT,DECREMENT} from './constant'
// function createIncrementAction(data){
//     return {type:'increment',data}
// }
export const createIncrementAction = data=>({type:INCREMENT,data})
// function createDecrementAction(data){
//     return {type:'decrement',data}
// }
export const createDecrementAction = data=>({type:DECREMENT,data})// export default {
//     createIncrementAction,
//     createDecrementAction
// }

redux/count_reducer.js

/*1.該文件是用于創建一個為count服務的reducer,reducer的本質就是一個函數2.reducer函數會接到兩個參數,分別為:之前的狀態(preState),動作對象(action)
*/
import {INCREMENT,DECREMENT} from "./constant";const initState = 0
export default function countReducer(preState=initState,action) {console.log('countReducer',preState,action)const {type,data} = action// 根據type決定如何加工數據switch (type){case INCREMENT:console.log('@')return preState + datacase DECREMENT:return preState - datadefault:return preState}
}

/redux/store.js

/*該文件專門用于創建一個為Count組件服務的store對象*/
//引入createStore,專門創建redux中最為核心的store對象
import {createStore} from 'redux'
//引入cunter.redux.js文件
import countReducer from './count_reducer'
//暴露store
export default createStore(countReducer)

3、src/App.js

import React, {Component} from "react";
import Count from "./components/Count";
export default class App extends Component {render(){return(<div><Count></Count></div>);}
}

src/index.js

import React from "react";
import ReactDOM from 'react-dom'
import App from './App'
ReactDOM.render(<App/>,document.getElementById('root'))

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/43120.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/43120.shtml
英文地址,請注明出處:http://en.pswp.cn/web/43120.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CSS【詳解】邊框 border,邊框-圓角 border-radius,邊框-填充 border-image,輪廓 outline

邊框 border border 是以下三種邊框樣式的簡寫&#xff1a; border-width 邊框寬度 —— 數值 px&#xff08;像素&#xff09;,thin&#xff08;細&#xff09;,medium&#xff08;中等&#xff09;,thick&#xff08;粗&#xff09;border-style 邊框線型 —— none【默認值…

78. UE5 RPG 創建技能數據并初始化技能ui

在上一篇文章里&#xff0c;我們創建了技能的UI&#xff0c;接下來&#xff0c;我們要考慮如何實現對技能UI的填充&#xff0c;肯定不能直接寫死&#xff0c;需要有一些方法去實現技能的更新。我們期望能夠創建一個技能數據&#xff0c;然后根據數據通過回調的方式實現數據的更…

GET正常,POST獲取不到數據

環境復現 前臺&#xff1a; wx.request({url: xxxxxx,method: POST,header: {"content-type": "application/json"},success(res) {console.log(res);},fail(err) {console.error(網絡請求失敗, err);}}); 后端使用springboot&#xff1a; RequestMappin…

一鍵掌握天氣動態 - 基于Vue和高德API的實時天氣查詢

前言 本文將學習如何使用Vue.js快速搭建天氣預報界面,了解如何調用高德地圖API獲取所需的天氣數據,并掌握如何將兩者有機結合,實現一個功能豐富、體驗出色的天氣預報應用 無論您是前端新手還是有一定經驗,相信這篇教程都能為您帶來收獲。讓我們一起開始這段精彩的Vue.js 高德…

桌面懸浮備忘錄哪個好?能在桌面懸浮使用的備忘app

備忘錄是我們日常工作和生活中的常用工具&#xff0c;它幫助我們記錄重要信息&#xff0c;提醒我們完成各項任務。而將備忘錄懸浮在桌面上使用&#xff0c;無疑能進一步提高我們的工作效率。想象一下&#xff0c;在處理復雜的工作任務時&#xff0c;你能夠隨時在桌面上查看提醒…

C++原創娛樂系列抽搐的井號

玩法&#xff1a; 一次性輸入大量w&#xff0c;s&#xff0c;a&#xff0c;d&#xff0c;然后即可欣賞抽搐的井號 上代碼 #include"bits/stdc.h" #include"Windows.h" using namespace std; int main(){int w10,a10;char n;while(1){for(int i0;i<w;…

JS獲取本機ip地址方法

前端獲取本機ip地址&#xff1b;使用第三方免費API <script>function ipJson(ipJson) {console.log(獲取到的網絡IP,ipJson);//可以把結果存在window上&#xff0c;方便調用window.ipJson ipJson;} </script> <script src"https://whois.pconline.com.cn/…

產品使用手冊深度剖析:五步快速敲定產品手冊策劃思路

引言 在這個信息爆炸的時代&#xff0c;產品使用手冊不僅是產品的“說明書”&#xff0c;更是品牌與用戶之間建立情感連接的橋梁。一份優秀的手冊&#xff0c;能夠迅速吸引用戶的注意力&#xff0c;引導他們輕松上手&#xff0c;并深入體驗產品的魅力。那么&#xff0c;如何撰…

ruoyi項目swagger文檔升級knife4j文檔

注釋admin模塊中的swagger依賴加入knife4j依賴 <!-- swagger3--> <!-- <dependency>--> <!-- <groupId>io.springfox</groupId>--> <!-- <artifactId>springfox-boot-starter</artifactId>--…

IDEA常用技巧薈萃:精通開發利器的藝術

1 概述 在現代軟件開發的快節奏環境中&#xff0c;掌握一款高效且功能全面的集成開發環境&#xff08;IDE&#xff09;是提升個人和團隊生產力的關鍵。IntelliJ IDEA&#xff0c;作為Java開發者的首選工具之一&#xff0c;不僅提供了豐富的編碼輔助功能&#xff0c;還擁有高度…

flowable框架 6.8 自定義函數方法

為了比對流程中條件的checkbox&#xff0c;由于本身elui的checkbox是亂序的&#xff0c;所以需要這個自定義函數來判斷 環境&#xff1a;jdk1.8 flowable6.8 springboot2 1.自定義函數 import org.springframework.stereotype.Component;import java.util.Arrays; import ja…

預算有限?如何挑選經濟適用的安全管理系統?

如今&#xff0c;無論是信息安全、生產安全還是人員安全&#xff0c;都直接關系到企業的穩定運營和長遠發展。然而&#xff0c;對于許多中小企業而言&#xff0c;高昂的安全管理系統投入往往成為一大難題。那么&#xff0c;在預算有限的情況下&#xff0c;如何挑選一款既經濟適…

Github 2024-07-07php開源項目日報 Top9

根據Github Trendings的統計,今日(2024-07-07統計)共有9個項目上榜。根據開發語言中項目的數量,匯總情況如下: 開發語言項目數量PHP項目9Blade項目2JavaScript項目1Laravel:表達力和優雅的 Web 應用程序框架 創建周期:4631 天開發語言:PHP, BladeStar數量:75969 個Fork數…

如何整合生成的人工智能?(GenAI)為你未來的工作增加動力

生成人工智能(GenAI)它發展迅速&#xff0c;以前所未有的速度取得了突破。人工智能將繼續改變各行各業&#xff0c;預計2023年至2030年的年增長率將達到37.3%。由于一種新的知識工作者現在面臨被取代的風險&#xff0c;生成式人工智能的驚人崛起進一步加劇了這種緊迫性。據《未…

如何快速學好一門新技術

目錄 學習步驟 1. 基本了解 2. 快速上手 3. 系統學習 4. 主動運用 5. 了解原理 6. 深入源碼 7. 修改源碼 8. 推陳出新 學到哪一步? 無論學習任何編程技術,都可以遵循以下步驟: 學習步驟 1. 基本了解 首先了解這項技術的用途、優缺點及適用場景。建議通過網上的經…

Apache Hadoop文件上傳、下載、分布式計算案例初體驗

上篇&#xff1a;Apache Hadoop完全分布式集群搭建無坑指南-CSDN博客 通過上篇&#xff0c;我們搭建了完整的Hadoop集群&#xff0c;此篇我們簡單通過集群上傳和下載文件&#xff0c;同時測試分布式worldCount案例。后續的篇章再對分布式計算、分布式存儲作更深的理解。 上傳…

嘎嘎詳細的三維變換詳細講解,包括視圖變換、投影變換等,超級通俗易懂!

前置二維空間的各種變換筆記&#xff1a;二維變換 三維空間中的齊次坐標 從二維變換開始引申&#xff0c;可得到三維中的一個點的表達方式為 ( x , y , z , 1 ) ? (\mathbf{x}, \mathbf{y}, \mathbf{z}, 1)^{\top} (x,y,z,1)?&#xff0c;也就是w1&#xff0c;而三維的向量…

插入排序算法(C語言版)

直接插入排序 插入排序&#xff08;insert sort&#xff09;是一種簡單的排序算法&#xff0c;它的工作原理與手動整理一副牌的過程非常相似。 具體來說&#xff0c;我們在未排序區間選擇一個基準元素&#xff0c;將該元素與其左側已排序區間的元素逐一比較大小&#xff0c;并…

如何用 Python 繞過 cloudflare(5秒盾) 抓取數據:也不是很難嘛!

大家好!我是愛摸魚的小鴻,關注我,收看每期的編程干貨。 逆向是爬蟲工程師進階必備技能,當我們遇到一個問題時可能會有多種解決途徑,而如何做出最高效的抉擇又需要經驗的積累。本期文章將以實戰的方式,帶你全面了解 cloudflare(5秒盾) 以及如何繞過使用 cloudflare 服務…

(自用)gtest單元測試

gtest是Google的一套用于編寫C測試的框架&#xff0c;可以運行在很多平臺上&#xff08;包括Linux、Mac OS X、Windows、Cygwin等等&#xff09;。基于xUnit架構。支持很多好用的特性&#xff0c;包括自動識別測試、豐富的斷言、斷言自定義、死亡測試、非終止的失敗、生成XML報…