ListView Parent中的Child ListView

Pau*_*aul 14 flutter

实现嵌套ListView的首选方法是什么,换句话说,可以包含在可滚动父级中的ListView小部件是什么?

想象一下"报告"页面,其中一个部分是逐项列表.

小智 42

对于子ListView,使用该参数:

shrinkWrap: true,
physics: ClampingScrollPhysics(),
Run Code Online (Sandbox Code Playgroud)

  • 当子列表视图嵌套在嵌套在嵌套在容器中的滚动配置中的滚动条中时,这对我不起作用 (2认同)
  • 感谢ClampingScrollPhysics():D (2认同)
  • 这适用于父级ListView内部的嵌套ListView!谢谢! (2认同)
  • 谢谢,ClampingScrollPhysics() 基本上将嵌套滚动条的长度添加到整个屏幕。非常有用,谢谢! (2认同)
  • 当 Listview => Listview.Builder 时滚动出现断断续续的情况 (2认同)

Bur*_*rak 26

添加physics: ClampingScrollPhysics()shrinkWrap: true为我做了诀窍。

示例代码:

@override
Widget build(BuildContext context) {
  return Container(
    child: Column(
      mainAxisSize: MainAxisSize.min,
      children: <Widget>[
        Expanded(
          child: ListView.builder(
              shrinkWrap: true,
              itemCount: 123,
              itemBuilder: (BuildContext context, int index) {
                return Column(
                  crossAxisAlignment: CrossAxisAlignment.start,
                  children: <Widget>[
                    Text('Parent'),
                    ListView.builder(
                        itemCount: 2,
                        physics: ClampingScrollPhysics(), 
                        shrinkWrap: true,
                        itemBuilder: (BuildContext context, int index) {
                          return Text('Child');
                        }),
                  ],
                );
              }),
        )
      ],
    ),
  );
}
Run Code Online (Sandbox Code Playgroud)


Col*_*son 13

如果你想让内部ListView可以独立于主滚动视图滚动,你应该使用NestedScrollView.否则,请使用CustomScrollView.

以下是一些说明该NestedScrollView方法的代码.

视频

import 'package:flutter/material.dart';

void main() {
  runApp(new MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: new MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      body: new NestedScrollView(
        headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
          return <Widget>[
            new SliverAppBar(
              pinned: true,
              title: new Text('Flutter Demo'),
            ),
          ];
        },
        body: new Column(
          children: <Widget>[
            new FlutterLogo(size: 100.0, colors: Colors.purple),
            new Container(
              height: 300.0,
              child: new ListView.builder(
                itemCount: 60,
                itemBuilder: (BuildContext context, int index) {
                  return new Text('Item $index');
                },
              ),
            ),
            new FlutterLogo(size: 100.0, colors: Colors.orange),
          ],
        ),
      ),
    );
  }
}
Run Code Online (Sandbox Code Playgroud)

  • 这不会完全滚动Flutterlogo.它停止滚动.如何滚动整个容器?我的意思是FlutterLogo是完全不可见的? (3认同)

Mim*_*han 12

对于内部列表视图,我刚刚添加了下面的代码,它为我解决了

shrinkWrap: true,
physics: ScrollPhysics(),
Run Code Online (Sandbox Code Playgroud)


Cop*_*oad 9

截屏:

在此处输入图片说明


代码:

var _container = Container(
  height: 200,
  color: Colors.blue,
  margin: EdgeInsets.symmetric(vertical: 10),
);

@override
Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(title: Text("ListView")),
    body: Padding(
      padding: const EdgeInsets.all(40.0),
      child: ListView( // parent ListView
        children: <Widget>[
          _container,
          _container,
          Container(
            height: 200, // give it a fixed height constraint
            color: Colors.teal,
            // child ListView
            child: ListView.builder(itemBuilder: (_, i) => ListTile(title: Text("Item ${i}"))),
          ),
          _container,
          _container,
          _container,
        ],
      ),
    ),
  );
}
Run Code Online (Sandbox Code Playgroud)


iDe*_*ode 9

感谢塞尔达·波拉特:

ListView.builder( // outer ListView
  itemCount: 4,
  itemBuilder: (_, index) {
    return Column(
      children: [
        Container(
          color: Colors.blue,
          alignment: Alignment.center,
          child: Text('Header $index'),
        ),
        ListView.builder( // inner ListView
          shrinkWrap: true, // 1st add
          physics: ClampingScrollPhysics(), // 2nd add
          itemCount: 10,
          itemBuilder: (_, index) => ListTile(title: Text('Item $index')),
        )
      ],
    );
  },
)
Run Code Online (Sandbox Code Playgroud)