React-redux

Redux的出现是为了解决state里的数据问题。在React中,数据在组件中是单向流动,数据从一个方向(父组件)流向另一个方向(子组件props),由于这个特征两个非父子关系的组件通讯就比较麻烦

http://cn.redux.js.org/docs/introduction/CoreConcepts.html保存一下文档的眼

那么Redux的概念啊什么乱七八糟的就不写了,官网都有介绍,如果你有vuex基础学起来会稍微得心应手,毕竟vue是借鉴Ag跟react的

那么初始化的逻辑流向大致就是如下:

组件——>reducer——>state——>其他组件

组件 (dispatch 发送命令 action)——>reducer (管理者/处理器,接收action,OK开始处理)——>state(change state)——>组件(订阅state,发现change了,改变state)

另外一种表现形式

User————>Event(事件)————>view( UI )————>actions————>store(reducer管理作出state变化)————>view(渲染UI)

概念什么的可以查阅上方的URL,自己也是刚刚学习,理解没那么深,慢慢的一步步使用,今天写个很基础的使用
需要注意的几个方法

提供 getState() 方法获取 state
提供 dispatch(action) 方法更新 state(此处需要一个reducer管理事件)
通过 subscribe(listener) 注册监听器

npm install redux -S

在此之前 我们首先编写一个样式,就是万恶的递增递减效果,复制下面的代码就行

App.js

  import React, { Component } from 'react';
  import { BrowserRouter as Router, Route, Link } from "react-router-dom"
  import './assets/css/App.css'



  class App extends Component {
    constructor(props){
      super(props)
      this.state={

      }
    }
    render() {
      return (
        <div className='app'>
            <span>1</span>
            <span className='btn' >Increase</span> 
            <span className='btn' >Decrease</span> 
        </div>
      );
    }
  }

  export default App;

注意一下你的css路径就行

App.css

.app{
  width: 100%;height: 100px;text-align: center;font-size: 40px;font-weight: 900
}

.btn{
  display:block;width: 300px;height: 60px;line-height: 60px;text-align: center;margin: 0 auto;background: blanchedalmond;cursor: pointer;border-radius: 10px;margin-bottom: 30px
}
.btn:nth-child(2){background: salmon}


效果还是非常好看的(^_^


之前建议过安装一下这个插件,没有安装的可以安装一下


安装好之后编写一个reducer,管理这个状态

安装好插件之后 直接输入rrd 回车即可

    export default (state =0, action={}) => {
        switch (action.type) {
                
            default:
                return state;
        }
    };

给他设置一个默认值,先放着
接着来到index.js,就是最顶级的大哥,编辑一下APP.js就好了

第一步 引入createState import { createStore } from 'redux'
第二步引入 刚才的文件 import reducer from './reducer/counter'
第三步store初始化 `const store = createStore(reducer)

接下来给他设置监听函数


监听使用subscribe函数,文档上面也有示例,这里我们简单写个监听

那么如何触发这个监听,就是dispatch方法

    store.subscribe(()=>{
        console.log('State Change',store.getState())
    })    
    
    store.dispatch({
        type:'INCREMENT'
    })

OK,直接这样既可,那么reducer就能监听到传输的type,就可以根据这个type做出相应的行为
回到reducer下面的counter.js 文件

    export default (state =0, action={}) => {
        switch (action.type) {
            case 'INCREMENT':
             return  state+10    
            default:
                return state;
        }
    };

此时我们刷新一下页面


成功触发了 监听函数并且得到了reducer返回的state数据,OK 接下来就很简单了,把dispatch写成方法传递过去

`

    store.subscribe(()=>{
        console.log('State Change',store.getState())
    })        
    
    
    
    ReactDOM.render(<App  value={store.getState()} onIncrement={()=>{
        store.dispatch({
                        type:'INCREMENT'
                    })
    }} />,document.getElementById('root'))

在App中接收props

可以看到state已经更新了但是我们的视图并没有渲染,如何重新触发渲染呢,将模板的render封装成一个函数,使用subscribe监听

此时已经可以触发效果了,这是最基础的使用,多敲几遍吧,递减效果也是照搬的

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,295评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,928评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,682评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,209评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,237评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,965评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,586评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,487评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,016评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,136评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,271评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,948评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,619评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,139评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,252评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,598评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,267评论 2 358

推荐阅读更多精彩内容