首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >未定义not本机平面列表项

未定义not本机平面列表项
EN

Stack Overflow用户
提问于 2019-07-01 05:14:11
回答 3查看 1.2K关注 0票数 0

我正在尝试将我的平板列表变成一个可重用的组件,但是我得到了一个错误。

代码语言:javascript
运行
复制
item is not defined.

如何让我的onpress函数访问可重用组件中的项?

代码:

代码语言:javascript
运行
复制
import React, { Component } from 'react';
import { Text, View } from 'react-native';



export const WebsiteFlatlist = (props) => {
    return(
        <FlatList
        data={props.data}
        keyExtractor={(item, index) => index.toString()}
        renderItem={({ item }) => (
            <TouchableOpacity
                onPress={props.onPress}
            >
                <View>
                    <View>
                        <Text>{item.location}</Text>
                    </View>
                </View>
            </TouchableOpacity>
        )}
    />

    )

};

使用:

代码语言:javascript
运行
复制
<WebsiteFlatlist data={places} onPress={() =>{this._onPress(item.location)}}/>




 _onPress = async (places) => {
        console.log(places)
    };                  
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-07-01 05:38:15

您应该绑定该项,并将一个函数直接传递给onPress道具。

代码语言:javascript
运行
复制
import React, { Component } from 'react';
import { Text, View } from 'react-native';



export const WebsiteFlatlist = (props) => {
    return(
        <FlatList
        data={props.data}
        keyExtractor={(item, index) => index.toString()}
        renderItem={({ item }) => (
            <TouchableOpacity
                onPress={props.onPress.bind(null, item)}
            >
                <View>
                    <View>
                        <Text>{item.location}</Text>
                    </View>
                </View>
            </TouchableOpacity>
        )}
    />

    )

};

用法:

代码语言:javascript
运行
复制
<WebsiteFlatlist data={places} onPress={this._onPress}/>

 _onPress = async (places) => {
        console.log(places)
    };  
票数 1
EN

Stack Overflow用户

发布于 2019-07-01 05:20:51

在您的onPress函数中,您应该这样做:

代码语言:javascript
运行
复制
onPress={this._onPress}

通过这种方式,您可以将_onPress(location)函数作为回调传递到平面列表。

票数 0
EN

Stack Overflow用户

发布于 2019-07-01 05:40:11

只在<WebsiteFlatlist onPress={this._onPress}>中传递函数引用。而在通用组件中做了一些修改。

  1. 分离renderItem组件。
  2. 在组件内部使用函数renderItem。
代码语言:javascript
运行
复制
const renderItem = (item) => {
return (
<TouchableOpacity onPress={()=>props.onPress(item)}>
   <View>
       <View>
           <Text>{item.location}</Text>
       </View>
   </View>
</TouchableOpacity>
)}

<FlatList
   data={props.data}
   keyExtractor={(item, index) => index.toString()}
   renderItem={
       ({ item }) => (this.renderItem(item))
   }
/>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56830275

复制
相关文章

相似问题

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