大佬教程收集整理的这篇文章主要介绍了Flutter 首页必用组件NestedScrollView,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
可以在其内部嵌套其他滚动视图的滚动视图,其滚动位置是固有链接的。
在普通的ScrollView
中, 如果有一个Sliver组件容纳了一个TabBarView
,它沿相反的方向滚动(例如,允许用户在标签所代表的页面之间水平滑动,而列表则垂直滚动),则该TabBarView
内部的任何列表都不会相互作用 与外部ScrollView
。 例如,浏览内部列表以滚动到顶部不会导致外部ScrollView
中的SliverAppBar
折叠以展开。
比如实现如下场景,当列表滚动时,隐藏AppBar
,用法如下:
nestedScrollView(
headerSliverBuilder: (BuildContext context,bool innerBoxIsScrolled) {
return <Widget>[SliverAppBar(
title: Text('老孟'),)];
},body: ListView.builder(itemBuilder: (BuildContext context,int indeX){
return Container(
height: 80,color: Colors.primaries[index % Colors.primaries.length],alignment: Alignment.center,child: Text(
'$index',style: TextStyle(color: Colors.white,fontSize: 20),),);
},itemCount: 20,)
效果如下:
用法如下:
nestedScrollView(
headerSliverBuilder: (BuildContext context,bool innerBoxIsScrolled) {
return <Widget>[SliverAppBar(
expandedHeight: 230.0,pinned: true,flexibleSpace: FlexibleSpaceBar(
title: Text('复仇者联盟'),BACkground: Image.network(
'http://img.haote.com/upload/20180918/2018091815372344164.jpg',fit: BoxFit.fitHeight,)
效果如下:
用法如下:
nestedScrollView(
headerSliverBuilder: (BuildContext context,bool innerBoxIsScrolled) {
return <Widget>[
SliverAppBar(
expandedHeight: 230.0,flexibleSpace: Padding(
padding: EdgeInsets.symmetric(vertical: 8),child: PageView(),SliverPersistentHeader(
pinned: true,delegate: StickyTabBarDelegate(
child: TabBar(
labelColor: Colors.black,controller: this._tabController,tabs: <Widget>[
Tab(text: '资讯'),Tab(text: '技术'),],];
},body: TabBarView(
controller: this._tabController,children: <Widget>[
refreshInDicator(
onrefresh: (){
print(('onrefresh'));
},child: _buildTabNewsList(_newsKey,_newsList),_buildTabNewsList(_technologyKey,_technologyList),)
StickyTabBarDelegate 代码如下:
class StickyTabBarDelegate extends SliverPersistentHeaderDelegate {
final TabBar child;
StickyTabBarDelegate({@required this.chilD});
@override
Widget build(
BuildContext context,double shrinkOffset,bool overlapsContent) {
return Container(
color: Theme.of(context).BACkgroundColor,child: this.child,);
}
@override
double get maxExtent => this.child.preferredSize.height;
@override
double get minextent => this.child.preferredSize.height;
@override
bool shouldRebuild(SliverPersistentHeaderDelegate oldDelegatE) {
return true;
}
}
效果如下:
通过scrollDirection
和reverse
参数控制其滚动方向,用法如下:
nestedScrollView(
scrollDirection: Axis.horizontal,reverse: true,...
)
scrollDirection
滚动方向,分为垂直和水平方向。
reverse
参数表示反转滚动方向,并不是由垂直转为水平,而是垂直方向滚动时,默认向下滚动,reverse
设置false,滚动方向改为向上,同理水平滚动改为水平向左。
controller
为滚动控制器,可以监听滚到的位置,设置滚动的位置等,用法如下:
_scrollController = ScrollController();
//监听滚动位置
_scrollController.addListener((){
print('${_scrollController.position}');
});
//滚动到指定位置
_scrollController.animateTo(20.0);
CustomScrollView(
controller: _scrollController,...
)
physics
表示可滚动组件的物理滚动特性,具体查看ScrollPhysics
老孟Flutter博客地址(近200个控件用法):http://laomengit.com
欢迎加入Flutter交流群(微信:laomENGIt)、关注公众号【老孟Flutter】:
@H_489_139@ | @H_489_139@ |
以上是大佬教程为你收集整理的Flutter 首页必用组件NestedScrollView全部内容,希望文章能够帮你解决Flutter 首页必用组件NestedScrollView所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。