我在滚动视图控制器中收到错误。这是错误:
flutter: 'package:flutter/src/widgets/scroll_controller.dart': Failed assertion: line 149 pos 12: '_positions.isNotEmpty': ScrollController not attached to any scroll views.
我使用了以下代码,我希望它能够生成:
return ListView(
controller: _mealScrollController,
children: <Widget>[
Container(
height: screenSize.height * 0.35,
),
WorkWidget(workTime: workTime.morning),
WorkWidget(workTime: workTime.morning),
WorkWidget(workTime: workTime.noon),
WorkWidget(workTime: workTime.evening),
WorkWidget(workTime: workTime.lateevening),
WorkWidget(workTime: workTime.night),
WorkWidget(workTime: workTime.midnight),
Container(
child: Center(
child: RotateWidget(
child: Icon(
Icons.refresh,
size: AppSize.medium,
),
onTap: widget.callBack,
),
),
),
],
);
从您给出的日志来看,错误似乎来自scroll_controller.dart
并且不是由引起的List<Widget>
在列表视图中。
如果在构建中初始化之前调用 ScrollController,我只能复制此行为。如果您可以提供有关如何使用 ScrollController 的完整最小重现,我们可以看一下。
这是一个可以复制该行为的示例。
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
var _scrollController = ScrollController();
@override
void initState() {
super.initState();
// Calling _scrollController first without being initialized in the build
// will cause this error: "ScrollController not attached to any scroll views."
debugPrint('This will cause an error ${_scrollController.position.atEdge}');
// I suggest using a listener if you're trying to
// trigger functions on scroll change
_scrollController.addListener(() {
if (_scrollController.position.atEdge) {
if (_scrollController.position.pixels == 0)
print('List scroll at top');
else {
print('List scroll at bottom');
}
}
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: LayoutBuilder(builder: (context, constraints) {
return ListView.builder(
controller: _scrollController,
itemCount: 10,
itemBuilder: (context, index) {
return Container(
height: constraints.maxHeight * 0.2,
color: index % 2 == 0 ? Colors.blueAccent : Colors.redAccent);
},
);
}),
);
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)