![](/img/trans.png)
[英]How to scroll the user at the exact position, which is somewhere between two views.?
[英]Flutter error: 'ScrollController not attached to any scroll views.' on scroll
每当我在列表视图中滚动时,我都会在控制台中收到此错误消息:
ScrollController not attached to any scroll views.
'package:flutter/src/widgets/scroll_controller.dart':
Failed assertion: line 110 pos 12: '_positions.isNotEmpty'
我一整天都在尝试解决这个问题,我想让其他人看看。 这段代码还有更多问题,但现在我主要对修复这个错误感兴趣。
我试过使用 Listview.builder,检查 hController.hasClients 和更多小东西。 他们似乎没有改变任何东西
class MyHome extends StatefulWidget {
@override
MyHomeState createState() => new MyHomeState();
}
class MyHomeState extends State<MyHome> with SingleTickerProviderStateMixin {
ScrollController hController;
ScrollController tController;
ScrollController fController;
ScrollController bController;
@override
void initState() {
super.initState();
hController = new ScrollController()..addListener(_scrollListener);
tController = new ScrollController()..addListener(_scrollListener);
fController = new ScrollController()..addListener(_scrollListener);
bController = new ScrollController()..addListener(_scrollListener);
}
@override
void dispose() {
super.dispose();
hController.removeListener(_scrollListener);
tController.removeListener(_scrollListener);
fController.removeListener(_scrollListener);
bController.removeListener(_scrollListener);
}
@override
Widget build(BuildContext context) {
return new DefaultTabController(
length: 4,
child: new Scaffold(
//Removed AppBar for readability
body: new TabBarView(
children: [
new Container(// hot
child: ListView(
controller: hController,
children: <Widget>[
Utils.show("hot")
],
),
),
new Container( //Trending
child: ListView(
controller: tController,
children: <Widget>[
Utils.show("trending")
],
),
),
new Container( //Fresh
child: ListView(
controller: fController,
children: <Widget>[
Utils.show("fresh")
],
),
),
new Container( //Best
child: ListView(
controller: bController,
children: <Widget>[
Utils.show("best")
],
),
),
],
),
));
}
void _scrollListener() {
if (hController.position.extentAfter == 0.0) {
setState(() {
Utils.show("hot");
});
}else if (tController.position.extentAfter == 0.0) {
setState(() {
Utils.show("trending");
});
} else if (fController.position.extentAfter == 0.0) {
setState(() {
Utils.show("fresh");
});
} else if (bController.position.extentAfter == 0.0) {
setState(() {
Utils.show("best");
});
}
}
}
编辑:为了清楚起见,我第一次发布这段代码时,我使用了两次 tController。 这当然是一个错误,但并没有解决错误。 在四个列表视图中的每一个中滚动时都会发生错误。
为避免此类错误,请使用 getter
ScrollController.hasClient
如果为 false,则不得调用与 [ScrollPosition] 交互的成员,例如 [position]、[offset]、[animateTo] 和 [jumpTo]。
例如:
if (_controller.hasClients) {
_controller.animateTo(
...
}
问题在_scrollListener
内部。
当您在if-else
中检查控制器时,场景中只有一个视图。 意味着只有一个listview
被渲染并且只有一个scrollcontroller
被完全设置。 但是在您的代码中,他们正在检查单个 function 中所有滚动控制器的位置。 这就是您收到此错误的原因。 首先检查 controller 是否有位置,只有在连接了 controller 并且视图正确呈现时才会有位置。 之后检查extentAfter
值。
前 -
if (hController.positions.length > 0 && tController.position.extentAfter == 0.0) {
}
else if (tController.positions.length > 0 && tController.position.extentAfter == 0.0) {
}
& 很快
查看controller没有client ant然后延时跳转:
if (!_scrollController.hasClients) {
_scrollController.animateTo(_scrollController.position.maxScrollExtent,
duration: const Duration(milliseconds: 500),
curve: Curves.easeInOut);
}
如果您正确粘贴代码 - 似乎可能有错误:
new Container(// hot
child: ListView(
controller: tController,
children: <Widget>[
Utils.show("hot")
],
),
),
new Container( //Trending
child: ListView(
controller: tController,
children: <Widget>[
Utils.show("trending")
],
),
),
你用过两次tController
没用过hController
更新你的 flutter sdk 它将解决这个问题 这对我来说是工作在你的 cmd 上运行这个 - flutter update
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.