- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我在 TabBarView 中有 ListView 小部件,以允许用户滚动浏览每个选项卡的内容。我想测试一些屏幕外的小部件。我按照这个滚动 ListView 以将相关的小部件显示在屏幕上:
How to find off-screen ListView child in widget tests?
在我将 ListView 放入 TabBarView 之前,它工作正常,然后失败。
我在 TabBarView 中重建了没有 ListView 的代码并且测试通过了。将 ListView 放在 TabBarView 中会导致测试失败:
'zero widgets with text "bbb" (ignoring offstage widgets)'
debugDumpApp()
输出显示这是因为没有滚动。
我的有状态小部件:
class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}
class _HomeState extends State<Home> with SingleTickerProviderStateMixin {
TabController _tabController;
@override
void initState() {
super.initState();
_tabController = TabController(length: 2, vsync: this);
}
@override
void dispose() {
_tabController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Scroll test'),
),
body: NestedScrollView(
headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
return [
SliverAppBar(
expandedHeight: 100.0,
bottom: TabBar(
controller: _tabController,
tabs: <Widget>[
Tab(
child: Text('Tab one'),
),
Tab(
child: Text('Tab two'),
)
],
),
)
];
},
body: TabBarView(
controller: _tabController,
children: <Widget>[
ListView(
children: <Widget>[
Container(
height: 800.0,
child: Text('aaa'),
),
Text('bbb')
],
),
ListView(
children: <Widget>[
Container(
height: 800.0,
child: Text('ccc'),
),
Text('ddd')
],
),
],
)
)
);
}
}
我的测试:
void main() {
Widget buildTestableWidget(Widget widget) {
return new MediaQuery(
data: new MediaQueryData(), child: new MaterialApp(home: widget));
}
Home home = Home();
testWidgets('scroll test', (WidgetTester tester) async {
await tester.pumpWidget(buildTestableWidget(home));
expect(find.text('aaa'), findsOneWidget);
expect(find.text('bbb'), findsNothing);
final Offset point = tester.getCenter(find.text("aaa"));
final gesture = await tester.startGesture(point);
await gesture.moveBy(const Offset(0.0, -400.0));
await tester.pump();
expect(find.text('bbb'), findsOneWidget);
});
}
这是一个错误还是我需要做一些不同的事情才能让 TestGesture.moveBy 在 TabBarView 中工作?非常感谢您的帮助。
最佳答案
我认为这个问题与拖动在可滚动区域之外结束这一事实有关,WidgetTester
有一个名为 dragFrom 的方法它会为您处理这种情况。
testWidgets('scroll test', (WidgetTester tester) async {
await tester.pumpWidget(buildTestableWidget(home));
expect(find.text('aaa'), findsOneWidget);
expect(find.text('bbb'), findsNothing);
final Offset point = tester.getCenter(find.text("aaa"));
await tester.dragFrom(point, Offset(0.0, -400.0));
await tester.pump();
expect(find.text('bbb'), findsOneWidget);
});
关于testing - 为什么 TestGesture.moveBy 在 TabBarView 中无法滚动?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56631961/
我一直在尝试使用标签更改应用栏标题的许多解决方案,我解决了它,但现在有一个小问题;按下选项卡时,应用栏会随选项卡而变化,但不会随选项卡 View 而变化。在选项卡栏 View 上向左或向右滑动会更改选
我使用 TabBarView 并且我注意到一些非常奇怪的事情。我在所有选项卡的小部件中放置了一些打印消息,以便在滑动选项卡时获得反馈。我得到了这些结果: 从 0 -> 1:选项卡 1 调用,选项卡 3
这是我的布局结构 这是主界面 ListView( children: [ _buildCarousel(), _buildHomeTabBar(), ], ) 这是 HomeT
如何为未选中的标签添加下划线,如下所示: https://ibb.co/mfkzKp 在这里您可以看到未选中的选项卡为灰色,选中的选项卡为蓝色。 最佳答案 我在文档中没有找到任何关于如何自定义禁用指标
我需要在 Flutter 中实现如下布局。 当用户滚动时,我希望整个布局滚动(隐藏标题和标签栏)。但是,我不能将 TabBarView 嵌套在 ListView 中,因为 TabBarView 没有限
我在 SingleChildScrollView 中创建了 TabBar。问题是我想用我的整个应用程序在 TabBarView 中创建可滚动的内容,而不是仅在 TabBarView 中滚动内容。我尝试
我想在我的 flutter 页面中添加一些标签,但没有一个只有标签的页面。 简而言之,我有一些输入字段,在它们下面我想放置我的标签。 我不断收到此错误:TabBarView 没有 TabControl
我想构建一个 UI,其中我在屏幕顶部有一些固定的小部件(在所有选项卡上可见),然后在它们下面我想要一个 TabBarView(底部有选项卡栏),这是否可能而不使您的自己的标签小部件还是 TabBarV
我的 Flutter 应用有 3 个标签页。当应用程序加载时,我希望它加载所有 3 个页面,而不仅仅是它将显示的页面。我的问题是,当滑动到我的其他选项卡时,加载内容需要一秒钟,然后它会显示动画。为这种
想要在 flutter 中克隆 playstore 首页应用栏滚动功能。 Playstore Appbar我正在尝试在 SliverAppBar 底部属性下制作一个包含静态选项卡的屏幕。每当我单击任何
我有一个包含项目列表的 TabBarView,我为每个项目分配了一个 Navigator.push 方法。目前该方法会跳转到新页面。 我的问题是,是否可以导航到 TabBarView 主体内的新页面?
Flutter 的新手,不知道如何在我的 UI 上设置大小限制,以免溢出。尝试使用选项卡制作一些不同的 UI,我在选项卡栏上方有一些组件。基本上我想要这样的东西: ------------------
我想使用 TabBar 和 BottomNavigationBar 来控制相同的 TabBarView,其主体是自定义小部件 RankingTable 的列表(仅在演示中放置一个并使用文本小部件作为第
TabBar 小部件有一个 onTap() 回调,允许检测用户何时刚刚按下了一个选项卡。这很有用,我们可以准备新的 tabView 来显示一些动态数据。 TabBar 小部件还有一个拖动功能,允许更改
我的 tabBar 有一个 StatelessWidget 小部件,其中包含 2 个 statefulWidget。问题是,当单击管理器以查看我的所有选项卡时(默认情况下登陆我的第一个选项卡),tab
我用 DefaultTabController 实现了一个基本的 TabBar 和 TabBarView,见下面的代码。 class MyApp2 extends StatelessWidget {
我有下面的代码来让 TabBarView 与条子效果一起工作。问题是当用户滚动到末尾时我需要加载更多数据。但是每次向下滚动时,_handleScrolling 函数都不会被触发。我必须再次上下滚动才能
我的问题是我想要一个 TabBarView 在 SingleChildScrollView 但它给了我这个错误:RenderFlex child 有非零弹性,但传入的高度约束是无界的。 如果我删除 S
我正在开发一个 flutter 应用程序。我有一个有六个 child 的底部栏。其中两个是 TabBar 屏幕,但我对它们有疑问。每当我在 TabBar/TabBarView 中更改选定的选项卡并移动
Check video for more clearifacation gitlab link 我的代码 import 'package:flutter/material.dart'; import
我是一名优秀的程序员,十分优秀!