首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更改屏幕FlatList onPress

更改屏幕FlatList onPress
EN

Stack Overflow用户
提问于 2017-08-28 17:01:27
回答 2查看 1.4K关注 0票数 0

我有两个屏幕。第一个屏幕是HomeScreen,第二个屏幕是ProfileScreen。我在HomeScreen上使用了FlatList,我想推送导航到另一个屏幕。但是当我使用这些代码时,我看到了错误消息:"Can‘t read property 'navigate’of undefined“

像这样的代码

代码语言:javascript
复制
class ProfileScreen extends Component {

    static navigationOptions = {
      title: 'Profile',
    };

    render() {
        const { navigate } = props.navigation;

        return <Text>Hello, I am profile!</Text>;
    }
 }




class HomeScreen extends Component {

    static navigationOptions = {
        title: 'Home',
    };


    constructor(props) {
        super(props);

        this.state = {
            data: [],

        };


    }

    getScreen() {
        this.props.navigation.navigate('Profile')
    }

    render() {

        return (
            <View>
                <FlatList
                    data={this.state.data}
                    renderItem={({ item }) => (
                        <TouchableHighlight underlayColor= 'transparent' onPress= {this.getScreen}>
                            <View style= {{width: 300, height: 'auto'}} >
                            <Text> {item.title} </Text>
                                <View style= {{width: 300, height: 1, backgroundColor: 'red', marginBottom: 30, marginTop: 15}} /> 
                            </View>
                        </TouchableHighlight>
                    )}
                />
            </View>
        );
    }
}



const AppNavigator = StackNavigator({
    Home: { screen: HomeScreen },
    Profile: { screen: ProfileScreen }
});
EN

回答 2

Stack Overflow用户

发布于 2017-08-28 20:31:17

在您的实现中,您正在丢失this的上下文。使用函数调用修复它:

代码语言:javascript
复制
renderItem={({ item }) => (
  <TouchableHighlight underlayColor='transparent' onPress={() => this.getScreen()}>
  ...
  </TouchableHighlight>
)}

此外,您还可以使用pattern:

代码语言:javascript
复制
const { navigate } = this.props.navigation;

navigate('Profile');
票数 0
EN

Stack Overflow用户

发布于 2017-08-29 01:53:05

在构造函数内部,将其绑定到您的getScreen方法。

只需在构造函数中添加以下代码行即可。

this.getScreen =this.getScreen.bind(此);

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45915325

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档