这个蓝色波浪有时候确实没必要,我目前觉得他唯一存在于长列表整屏幕时挺好看的,但是各种小的模块(比如: 一般用listview做的导航列表或者gridview做的宫格布局的图表导航)就没啥必要了,要命的是长列表下嵌套这种小的listview组件时,不仅有局部丑陋的蓝色的波纹,还有严重的体验问题,手指划到局部listview时会触发局部listview的滚动,与外层大的滚动组件冲突,所以有时候用wrap这种流布局可能会更好。
那么,非要用listview,毕竟listview构建这种列表数据时特别方便,怎么办?
- 导入io包和基础的material的包
import 'dart:io';
import 'package:flutter/services.dart';
- 用ScrollConfiguration包裹滑动子布局:
ScrollConfiguration(
behavior: MyBehavior(), //自定义behavior
child: ListView() //你的滚动布局组件
);
- 自定义behavior:
class MyBehavior extends ScrollBehavior{
@override
Widget buildViewportChrome(BuildContext context, Widget child, AxisDirection axisDirection) {
if(Platform.isAndroid||Platform.isFuchsia){
return child;
}else{
return super.buildViewportChrome(context,child,axisDirection);
}
}
}
亲测好用,方法借鉴于:[这里](https://www.jianshu.com/p/b9e92c37f4ec)
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。