React-Native回调函数/方法不起作用

问题描述 投票:1回答:2

我阅读了几个教程,但我不明白为什么传递回调函数和回调方法都不起作用。

当我在console.log中时,回调函数是未定义的。

请帮忙。

import React, { Component } from 'react';
import { FlatList } from 'react-native';
import { RecipeCard } from '../RecipeCard/RecipeCard';
import recipeData from '../../config/SampleDataRecipeList.json';

class RecipeList extends Component {
  constructor(props) {
    super(props);
    this.handlePress = this.handlePress.bind(this);
  }
  state = {};

  handlePress() {
    console.log('Handle Press');
  }

  handleClick = () => {
    console.log('Handle Click');
  };

  renderItem({ item }) {
    return (
      <RecipeCard
        title={item.title}
        persons={item.persons}
        time={item.time}
        uri={item.uri}
        onPress={this.handlePress}
      />
    );
  }

  render() {
    return (
      <FlatList
        data={recipeData}
        renderItem={this.renderItem}
        keyExtractor={(item, index) => index.toString()}
      />
    );
  }
}

export { RecipeList };
reactjs react-native callback react-native-ios
2个回答
1
投票

我建议使用像下面这样的箭头函数:

  renderItem = item => {
    return (
      <RecipeCard
        title={item.title}
        persons={item.persons}
        time={item.time}
        uri={item.uri}
        onPress={this.handlePress}
      />
    );

0
投票

解决方案是更改为在构造函数中绑定renderItem或将其更改为胖箭头函数

renderItem = ( ) => {...}
© www.soinside.com 2019 - 2024. All rights reserved.