我有一个数据列表,我想放在FlatList(即ScrollView)中,每当我尝试向下滚动查看列表的更多内容时,ScrollView只会反弹到列表的顶部,所以我无法看到列表的底部。
我正在使用Expo,奇怪的是,如果我只是创建一个新项目或将一些代码复制/粘贴到Snack中,那么滚动工作就可以了。只有在我当前的项目中,我无法获得滚动列表。我甚至进入了main.js
文件,只是将我的示例代码粘贴在那里,问题仍然存在。
我的示例代码位于此处:https://snack.expo.io/ryDPtO5-b我已将此确切代码粘贴到我的项目中,并且无法按预期工作。
版本:RN 0.44 / Expo SDK 17.0.0 / React:16.0.0-alpha.6
我的项目的实际用例涉及将FlatList组件放在屏幕的底部三分之一处以显示作业列表。这是我发现错误的地方,当我开始尝试调试问题时。在我的项目中,我有一个父亲View
与{flex: 1
的风格与List
的孩子,其中包含FlatList
... List
来自react-native-elements
编辑
这是我实际尝试使用的代码:
<View style={styles.container}>
<View style={containerStyles.headerContainerStyle}>
<Text style={[textStyles.h2, { textAlign: "center" }]}>
Territory: {this.props.currentTerritory}
</Text>
</View>
<View style={styles.mapContainer}>
<MapView
provider="google"
onRegionChangeComplete={this.onRegionChangeComplete}
region={this.state.region}
style={{ flex: 1 }}
>
{this.renderMapMarkers()}
</MapView>
</View>
<Badge containerStyle={styles.badgeStyle}>
<Text>Orders Remaining: {this.props.jobsList.length}</Text>
</Badge>
<List containerStyle={{ flex: 1 }}>
<FlatList
data={this.props.jobsList}
keyExtractor={item => item.id}
renderItem={this.renderJobs}
removeClippedSubviews={false}
/>
</List>
</View>;
还有我所有的风格
const styles = StyleSheet.create({
container: {
flex: 1,
},
mapContainer: {
height: 300,
},
badgeStyle: {
backgroundColor: 'green',
alignSelf: 'center',
marginTop: 15,
width: 300,
height: 35,
},
});
最后,我的renderItem函数:
renderJobs = ({ item }) => {
const { fullAddress, pickupTime } = item;
return (
<ListItem
containerStyle={
item.status === "active" && { backgroundColor: "#7fbf7f" }
}
title={fullAddress}
titleStyle={{ fontSize: 14 }}
subtitle={pickupTime}
subtitleStyle={{ fontSize: 12, color: "black" }}
onPress={() =>
this.props.navigation.navigate("jobActions", { job: item })
}
/>
);
};
我能够解决这个问题。
解决方案是在renderRow返回组件<View style={{flex:1}}>
之后使用flatlist组件<View style={{flex:1}}>
我很困惑 - 你使用的是FlatList
还是ScrollView
--这两个元素有完全不同的生命周期事件(FlatList
要求你定义各个行将如何渲染及其键,而ScrollView
希望子元素与组件内联呈现)。
无论如何,我认为问题出在你的结构中,听起来像List
元素也需要一个height属性({flex: 1}
),因为绝对父级填充它的空间,但List
组件没有预定义的高度。
通过向根添加flex:1解决了这个问题
所以今天调试了一下之后我最终只创建了一个全新的Expo项目并将我的所有源代码复制/粘贴到新项目中,将我的Github项目名称更改为新名称,并将远程源设置为我的github在我的新本地项目上的repo(我改名的那个)。
出于某种原因,世博项目似乎存在问题。几乎看起来项目的实际NAME
导致问题,因为我试图将NEW项目的名称更改为原始项目的名称,但它不起作用。它只适用于做一个全新的项目,但使用完全相同的源代码。