我正在考虑实现 SliverAppBar 和它下面的 Scrollable 项目,所以我现在有这个代码:
CustomScrollView(
semanticChildCount: categoryItems.length,
physics: BouncingScrollPhysics(),
slivers: [
SliverAppBar(
automaticallyImplyLeading: false,
backgroundColor: Colors.white,
elevation: 0,
actions: [
Padding(
padding: EdgeInsets.only(right: 15),
child: IconButton(
onPressed: () {},
icon: Icon(
Icons.more_horiz,
color: changeColor == 80 ? Color(0xFFB2A588) : Colors.white,
size: 30,
),
),
)
],
expandedHeight: MediaQuery.of(context).size.height / 3,
stretch: true,
pinned: true,
flexibleSpace: LayoutBuilder(
builder: (BuildContext context, BoxConstraints constraints) {
// setting state for top to change color of more horiz
WidgetsBinding.instance.addPostFrameCallback((_) => setState(() {
changeColor = constraints.biggest.height;
}));
return FlexibleSpaceBar(
title: Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
constraints.biggest.height == 80 ? 'Title' : '',
style: TextStyle(
fontSize: 25,
fontWeight: FontWeight.bold,
color: Color(0xFFB2A588),
),
),
Visibility(
visible: constraints.biggest.height == 80,
child: Icon(
Icons.keyboard_arrow_down,
size: 35,
color: Color(0xFFB2A588),
),
)
],
),
stretchModes: [
StretchMode.zoomBackground,
],
background: Stack(
children: [
// category image
Image.network(
'networkimage',
fit: BoxFit.cover,
width: double.infinity,
),
// category title
Positioned(
bottom: 30,
left: 30,
child: Row(
children: [
SizedBox(
width: MediaQuery.of(context).size.width / 2.5,
child: Text(
'Title',
style: TextStyle(
fontSize: 60,
fontWeight: FontWeight.bold,
color: Colors.white),
),
),
],
),
),
// button
Positioned(
bottom: 30,
right: 30,
child: SizedBox(
width: MediaQuery.of(context).size.width / 4,
child: RaisedButton(
onPressed: () {
Navigator.pop(context);
},
color: Colors.white,
elevation: 4.0,
child: Text('View more',
style: TextStyle(
fontSize: 20,
fontWeight: FontWeight.w600,
color: Colors.black)),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(25.0)),
),
),
),
],
),
);
}),
),
SliverList(
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
print(index); },
childCount: categoryItems.length,
),
)
],
)
print(index) 语句每秒不断执行。任何想法为什么会发生这种情况?第一次合作SliverList
。
PS如果你把一些ListTile
s 例如放在里面SliverChildBuilderDelegate
它仍然会不断地执行 print 语句。