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 コンポーネントを画面の下 3 分の 1 に配置して、ジョブのリストを表示します。ここでエラーを発見し、問題のデバッグを試み始めました。私のプロジェクトでは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 })
}
/>
);
};