我正在尝试将对象提交给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;