Redux使用示例

Redux 使用示例(获取区域列表)

一、action

定义动作

export const RECEIVE_AREA = "RECEIVE_AREA";

import httpUtil from '../net/HttpUtil';
import Apicfg from '../net/ApiConfig';
var Apis = new Apicfg();

//action(返回值为对象,其中必须包含type值)
export const receiveAreas = data => {
    return {
        type: RECEIVE_AREA,
        data
    }
};

//获取列表(中间件,需要请求网络调用此方法)
export const getZones = () => (dispatch, state) => {
    var params = {
        service: Apis.GROUP_DETAIL
    };
    return dispatch(dispatch => httpUtil.post(params, function (data) {
        if (data.code == 0) {
            dispatch(receiveZone(data.body));
        } else {
            console.log("msg: " + data.msg);
        }
    }));
};

请求中间件之后会执行下面HttpUtil中的post函数,请求成功后会执行成功的回调方法;执行完action的函数之后会将其返回值作为参数,自动执行reducer中的函数,返回值作为第二个参数

如果不需要请求网络,直接发送普通action即可

HttpUtil

import $ from 'jquery';

export default {

    /**
     *网络请求
     * @param params  请求参数
     * @param successCallback 请求成功回调方法
     * @param url 请求地址(若非特殊情况,该参数不需要传,使用默认值即可)
     */
    post(params,
         successCallback = function (data) {
             console.error("data: ", JSON.stringify(data));
         }, url = "/api/gateway"){
        console.log("request url: " + url + ", params: " + JSON.stringify(params));
        $.ajax({
            url: url,
            type: 'post',
            data: params,
            dataType: 'json',
            success: successCallback.bind(this),
            error: function (xhr, status, err) {
                console.error("error: ", status, err.toString());
            }.bind(this)
        });
    }
}

二、reducer

执行动作

./repair/Area.js

import {RECEIVE_AREA} from '../../actions/repair/Area';

//reducer(第一个参数为上一次返回值,第二个参数为action返回值)
export function areaList(state = [], action) {
    switch (action.type) {
        case RECEIVE_AREA:
            return action.data;
        default:
            return state;
    }
}

程序加载时会初始化reducer中的函数,返回值为定义的初始值,switch中必须有返回值,否则程序将出错,建议直接返回state

index.js

import {combineReducers} from 'redux';
import {areaList} from './repair/Area';

const todoApp = combineReducers({
    areaList
});


export default todoApp;

创建store时会指定reducer文件,所以需要将自定义的reducer在index.js文件中注册,切记!!!

三、containers

准备结果

import {connect} from 'react-redux';
import Header from '../../components/repair/area/Header';

//将state的值存放到props上,方便取用
//state为全局唯一的state,areaList为reducer中定义的函数名
function mapStateToProps(state) {
    return {
        areaList: state.areaList
    }
}

export default connect(mapStateToProps)(Header);

通过connect方法将ReactRedux连接,只有连接的React组件(上面的Header)才可以通过this.props.xxx获取到上面mapStateToProps方法中返回对象的Key获取到state中相对应的值。

四、component

请求和获取结果

import React from 'react';

//引入action定义的函数
import {getAreas} from '../../../actions/repair/Area';

export default React.createClass({

     //页面加载时通过dispatch方法发送action
    componentDidMount(){
        this.props.dispatch(getAreas({group_id: 1}))
    },

    render(){
          //通过this.props获取containers定义的值
        var areaList = this.props.areaList;
        if (areaList.length > 0) {
            console.log("areaList: " + JSON.stringify(areaList[0]));
        }
        
        return (
            <div>
              区域配置
            </div>
        )
    }
})

通过dispatch发送action,修改state之后会重新渲染页面,如同ReactsetState方法,实际使用中根据需求可以二者并用。

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

推荐阅读更多精彩内容