调用reducer或redux props重新渲染页面时,redux reducer会使expo应用程序崩溃

时间:2018-09-28 08:44:27

标签: javascript reactjs react-native redux react-redux

我正在尝试将对象提交给redux reducer,并且可以一直获取数据到reducer,但是当我单击按钮时,expo app崩溃,没有错误指示符。

如果我不更改状态,则提交按钮可以正常工作。但是,如果尝试尝试,应用程序会崩溃。我认为这不是导致崩溃的重新渲染循环。但不确定从这里走什么方向。

//reducer page
import { ADD_NEW_PROGRAM } from "../actions/programActions";

export const inititalState = {
  programList: [{ title: "Title", description: "Dez Nuts, got em" }]
};

export default function(state = inititalState, action) {
  switch (action.type) {
    case ADD_NEW_PROGRAM:
      console.log("inside reducer", action.payload.title);
      return { // this is causing the crash I believe, should be correct to push/add to the initalState array.
        ...state,
        programList: [...state.programList, action.payload]
      };

    default:
      return state;
  }
}

import React, { Component } from "react";
import { Text, View } from "react-native";
import * as firebase from "firebase";
require("firebase/firestore");
import { connect } from "react-redux";

import Program from "./Program";
import { CreateButton } from "../Buttons/Buttons";
import { globalStyles } from "../../index";
import { addProgramAction } from "../../actions/programActions";

class ProgramContainer extends Component {
  static navigationOptions = {
    title: "Programs"
  };

  constructor(props) {
    super(props);
  }

  componentDidUpdate() {
    const newProgram = this.props.navigation.getParam("completed", false);
    const data = {
      title: this.props.navigation.getParam("name"),
      description: this.props.navigation.getParam("description")
    };

    newProgram ? this.props.addProgramAction(data) : null;
  }


  render() {
    const { programList } = this.props;
    const { navigation } = this.props;

    return (
      <View style={{ flex: 1 }}>
        <Program add={this.addToDatabase} programList={programList} /> // this is where the array will .map
        <CreateButton navigation={this.props.navigation} /> // this is the submit button
      </View>
    );
  }
}

const mapStateToProps = state => ({
  programList: state.programReducer.programList
});

export default connect(
  mapStateToProps,
  { addProgramAction }
)(ProgramContainer);

import React from "react";
import { View, Text } from "react-native";
import { List, ListItem } from "react-native-elements";


const Program = ({ add, programList }) => {
  return (
    <View style={{ flex: 1 }}>
      <List containerStyle={{ marginBottom: 20 }}>
        {programList.map(obj => (
          <ListItem
            roundAvatar
            avatar={{}}
            avatarContainerStyle={{ backgroundColor: "#d9534f" }}
            key={obj.title}
            title={obj.title}
            subtitle={obj.description}
            onPress={() => {
              console.log("no functions");
            }}
          />
        ))}
      </List>
    </View>
  );
};

export default Program;

0 个答案:

没有答案