首页 > 解决方案 > ScrollView 内的 FlatList 不滚动

问题描述

我有 4FlatList秒,其中maxHeight设置200ScrollView.

<ScrollView>
  <FlatList/>
  <FlatList/>
  <FlatList/>
  <FlatList/>
</ScrollView>

当我尝试滚动 aFlatList时,它不会滚动,而是ScrollView滚动。我该如何解决这个问题?

完整的源代码

import { Component, default as React } from 'react';
import { FlatList, ScrollView, Text } from 'react-native';

export  class LabScreen extends Component<{}> {
  render() {
    return (
      <ScrollView>
        {this.renderFlatList('red')}
        {this.renderFlatList('green')}
        {this.renderFlatList('purple')}
        {this.renderFlatList('pink')}
      </ScrollView>
    );
  }

  getRandomData = () => {
    return new Array(100).fill('').map((item, index) => {
      return { title: 'Title ' + (index + 1) };
    });
  };

  renderFlatList(color: string) {
    return (
      <FlatList
        data={this.getRandomData()}
        backgroundColor={color}
        maxHeight={200}
        marginBottom={50}
        keyExtractor={(item, index) => index.toString()}
        renderItem={({ item }) => <Text>{item.title}</Text>}
      />
    );
  }
}

小吃博览会链接

标签: react-native

解决方案


我们可以为子 FlatList/ScrollView 组件使用内置的nestedscrollenabled属性。

<FlatList nestedScrollEnabled />

这仅对 Android 是必需的(iOS 默认支持嵌套滚动)。


推荐阅读