React Native - TypeError:null 不是对象

IT技术 javascript reactjs react-native
2021-05-15 05:32:49

我仍在学习本机react,我正在尝试从 API 检索数据并将其作为自定义单选按钮返回,但是如果我确实调用了 API,则会收到此错误:

null 不是一个对象(评估'this.props.activities.map')

 {this.props.activities.map((val, index) => {
    let { key, type, placeholder } = val;

    if (type === "selection") {
      var buttons = [];

      placeholder.forEach((e, index) => {
        var selectedButton = img.findButton(e, true);
        var normalButton = img.findButton(e);

        buttons.push(
          <RadioButton
            key={index}
            value={e}
            element={<Image source={selectedButton} />}
            selectedElement={<Image source={normalButton} />}
            onPress={() => this.changeSelection(key, e)}
            selected={this.state[key]["value"]}
          />
        );
      });

      var rows = [],
        columns = [];
      var i = 0;

      buttons.forEach((e, index) => {
        rows.push(e);
        i++;

        if (i === 2 || index === buttons.length - 1) {
          //max buttons per row
          i = 0;
          columns.push(
            <View key={index} style={{ flex: 1, flexDirection: "row" }}>
              {rows}
            </View>
          );
          rows = [];
          i = 0;
        }
      });

      return (
        <View key={key} style={{ flex: 1, margin: normalize(20) }}>
          {columns}
        </View>
      );
    }
  })}

'this.props.activites' 来自于此

let initialState = {
    activities: null,

};

export default function mainReducer(state = initialState, action) {
    switch (action.type) {
        case t.RECEIVE_ACT:
            return Object.assign({}, state, { actReceived: true, activities: action.activities });
        case t.EMPTY_ACT:
            return Object.assign({}, state, { actReceived: false, activities: null });
        default:
            return state;
    }
}

我想知道它是怎么变成空的

3个回答

的初始状态activitiesnull因此,在您从 api 得到响应之前,React 会使用该null呈现代码的那部分您可以将activities: []初始值作为初始值,也可以在您的 map 函数之前给出,如果它为 null 或不为 null,例如

{this.props.activities && this.props.activities.map((val, index) => {...

如果你打算使用activities: []那么你仍然可以在你的地图之前进行检查,虽然它是可选的但仍然很好,例如;

{this.props.activities.length && this.props.activities.map((val, index) => {...

哪里this.props.activities来的?

它是否是异步的,因为它似乎null在某个点上。

如果添加以下行,您应该不会再看到此错误。

this.props.activities && this.props.activities.map(.....

保罗的回答是万无一失的,但您也可以使用默认值来避免 falsy values

YourComponent.defaultProps = {
    activities: []
}