Flutter實現(xiàn)懸浮分組列表功能
在本篇博客中,我們將介紹如何使用 Flutter 實現(xiàn)一個帶有分組列表的應用程序。我們將通過 CustomScrollView 和 Sliver 組件來實現(xiàn)該功能。
需求
我們需要實現(xiàn)一個分組列表,分組包含固定的標題和若干個列表項。具體分組如下:
- 水果
- 動物
- 職業(yè)
- 菜譜
每個分組包含若干個項目,例如水果組包含蘋果、香蕉等。
效果

實現(xiàn)思路
- 定義數(shù)據(jù)模型:創(chuàng)建
ItemBean類來表示每個分組的數(shù)據(jù)。 - 構(gòu)建主頁面:使用
CustomScrollView和Sliver組件構(gòu)建主頁面,其中包含多個分組。 - 實現(xiàn)固定標題:通過自定義
SliverPersistentHeaderDelegate實現(xiàn)固定標題。
實現(xiàn)代碼
以下是實現(xiàn)代碼:
import 'package:flutter/material.dart';
/// 數(shù)據(jù)源
/// https://github.com/yixiaolunhui/flutter_xy
class ItemBean {
final String groupName;
final List<String> items;
const ItemBean({required this.groupName, this.items = const []});
static List<ItemBean> get groupListData => const [
ItemBean(groupName: '水果', items: [
'蘋果', '香蕉', '橙子', '葡萄', '芒果', '梨', '桃子', '草莓', '西瓜', '檸檬',
'菠蘿', '櫻桃', '藍莓', '獼猴桃', '李子', '柿子', '杏', '楊梅', '石榴', '木瓜'
]),
ItemBean(groupName: '動物', items: [
'狗', '貓', '獅子', '老虎', '大象', '熊', '鹿', '狼', '狐貍', '猴子',
'企鵝', '熊貓', '袋鼠', '海豚', '鯊魚', '斑馬', '長頸鹿', '鱷魚', '孔雀', '烏龜'
]),
ItemBean(groupName: '職業(yè)', items: [
'醫(yī)生', '護士', '教師', '工程師', '程序員', '律師', '會計', '警察', '消防員', '廚師',
'司機', '飛行員', '科學家', '記者', '設計師', '作家', '演員', '音樂家', '畫家', '攝影師'
]),
ItemBean(groupName: '菜譜', items: [
'紅燒肉', '糖醋排骨', '宮保雞丁', '麻婆豆腐', '魚香肉絲', '酸辣湯', '蒜蓉菠菜', '回鍋肉', '水煮魚', '烤鴨',
'蛋炒飯', '蠔油生菜', '紅燒茄子', '西紅柿炒雞蛋', '油燜大蝦', '香菇雞湯', '酸菜魚', '麻辣香鍋', '鐵板牛肉', '干煸四季豆'
]),
];
}
/// 分組列表
class GroupListPage extends StatelessWidget {
const GroupListPage({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('分組列表')),
body: CustomScrollView(
slivers: ItemBean.groupListData.map(_buildGroup).toList(),
),
);
}
Widget _buildGroup(ItemBean itemBean) {
return SliverMainAxisGroup(
slivers: [
SliverPersistentHeader(
pinned: true,
delegate: HeaderDelegate(itemBean.groupName),
),
SliverList(
delegate: SliverChildBuilderDelegate(
(_, index) => _buildItemByUser(itemBean.items[index]),
childCount: itemBean.items.length,
),
),
],
);
}
Widget _buildItemByUser(String item) {
return Container(
alignment: Alignment.center,
height: 50,
child: Row(
children: [
const Padding(
padding: EdgeInsets.only(left: 20, right: 10.0),
child: FlutterLogo(size: 30),
),
Text(
item,
style: const TextStyle(fontSize: 16),
),
],
),
);
}
}
class HeaderDelegate extends SliverPersistentHeaderDelegate {
final String title;
const HeaderDelegate(this.title);
@override
Widget build(
BuildContext context, double shrinkOffset, bool overlapsContent) {
return Container(
alignment: Alignment.centerLeft,
color: Colors.grey,
padding: const EdgeInsets.only(left: 20),
height: 40,
child: Text(title, style: const TextStyle(fontSize: 16)),
);
}
@override
double get maxExtent => 40;
@override
double get minExtent => 40;
@override
bool shouldRebuild(covariant HeaderDelegate oldDelegate) {
return title != oldDelegate.title;
}
}通過以上代碼,我們實現(xiàn)了一個簡單的 Flutter 分組列表應用。每個分組都有固定的標題,點擊標題可以展開或收起組內(nèi)的項目。希望這篇博客對你有所幫助!
詳情 :github.com/yixiaolunhui/flutter_xy
到此這篇關于Flutter-實現(xiàn)懸浮分組列表的文章就介紹到這了,更多相關Flutter懸浮分組列表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Flutter定義tabbar底部導航路由跳轉(zhuǎn)的方法
這篇文章主要為大家詳細介紹了Flutter定義tabbar底部導航路由跳轉(zhuǎn)的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07
Android使用popupWindow仿微信彈出框使用方法
這篇文章主要為大家詳細介紹了Android使用popupWindow仿微信彈出框使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-09-09
android ScrollView實現(xiàn)水平滑動回彈
這篇文章主要為大家詳細介紹了android ScrollView實現(xiàn)水平滑動回彈,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04
Android編程連接MongoDB及增刪改查等基本操作示例
這篇文章主要介紹了Android編程連接MongoDB及增刪改查等基本操作,簡單介紹了MongoDB功能、概念、使用方法及Android操作MongoDB數(shù)據(jù)庫的基本技巧,需要的朋友可以參考下2017-07-07
Android入門教程之RecyclerView的具體使用詳解
RecyclerView是Android一個更強大的控件,其不僅可以實現(xiàn)和ListView同樣的效果,還有優(yōu)化了ListView中的各種不足。其可以實現(xiàn)數(shù)據(jù)縱向滾動,也可以實現(xiàn)橫向滾動(ListView做不到橫向滾動)。接下來講解RecyclerView的用法2021-10-10

