当前位置: 首页 > news >正文

flutter_slidable 插件使用

简介
flutter_slidable 是一个用于创建可滑动列表项的 Flutter 插件,它允许用户通过滑动来显示隐藏的操作按钮,比如删除、分享等功能。
请添加图片描述

安装
在 pubspec.yaml 中添加依赖(并运行 flutter pub get):

dependencies:flutter_slidable: ^4.0.0

基本使用

  1. 导入包
import 'package:flutter_slidable/flutter_slidable.dart';
  1. 基本结构
    Slidable 的基本结构包含以下几个主要部分:
Slidable(key: ValueKey(item), // 唯一标识endActionPane: ActionPane( // 滑动操作面板motion: ScrollMotion(), // 滑动动画children: [ // 操作按钮列表SlidableAction(...),SlidableAction(...),],),child: ListTile(...), // 主要内容
)
  1. 完整示例
    下面是一个结合 TabBar 的完整示例:
import 'package:flutter/material.dart';
import 'package:flutter_slidable/flutter_slidable.dart';void main() {runApp(const MyApp());
}class MyApp extends StatelessWidget {const MyApp({super.key});@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Slidable TabBar Demo',theme: ThemeData(colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue), useMaterial3: true, ),home: const MyHomePage(),);}
}class MyHomePage extends StatefulWidget {const MyHomePage({super.key});@overrideState<MyHomePage> createState() => _MyHomePageState();
}class _MyHomePageState extends State<MyHomePage> with TickerProviderStateMixin {late TabController _tabController;final List<String> _tabs = ['Tab 1', 'Tab 2', 'Tab 3'];final List<List<String>> _items = [List.generate(20, (index) => 'Item 1-${index + 1}'),List.generate(20, (index) => 'Item 2-${index + 1}'),List.generate(20, (index) => 'Item 3-${index + 1}'),];@overridevoid initState() {super.initState();_tabController = TabController(length: _tabs.length, vsync: this);}@overridevoid dispose() {_tabController.dispose();super.dispose();}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('Slidable TabBar Demo'),bottom: TabBar(controller: _tabController,tabs: _tabs.map((String tab) => Tab(text: tab)).toList(),),),body: SlidableAutoCloseBehavior( // 自动关闭其他Slidablechild:  TabBarView(controller: _tabController,children: _items.map((tabItems) => KeepAliveListView(items: tabItems)).toList(),),),);}
}class KeepAliveListView extends StatefulWidget {final List<String> items;const KeepAliveListView({super.key,required this.items,});@overrideState<KeepAliveListView> createState() => _KeepAliveListViewState();
}// 保持状态的生命周期
class _KeepAliveListViewState extends State<KeepAliveListView>with AutomaticKeepAliveClientMixin { @overridebool get wantKeepAlive => true; // 必须实现@overrideWidget build(BuildContext context) {super.build(context); // 必须调用return ListView.builder(itemCount: widget.items.length,itemBuilder: (context, index) {return Slidable(key: ValueKey(widget.items[index]),endActionPane: // 滑动动作面板,可以自定义ActionPane(motion: const ScrollMotion(),children: [SlidableAction(onPressed: (context) {ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text('Delete ${widget.items[index]}')),);// 删除操作if (mounted){setState(() {widget.items.removeAt(index);});}},backgroundColor: Colors.red,foregroundColor: Colors.white,icon: Icons.delete,label: 'Delete',),SlidableAction(onPressed: (context) {ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text('Share ${widget.items[index]}')),);if (mounted){setState(() {widget.items.removeAt(index);});}},backgroundColor: Colors.blue,foregroundColor: Colors.white,icon: Icons.share,label: 'Share',),],),child: ListTile(title: Text(widget.items[index]),),);},);}
}

核心功能说明

  1. SlidableAutoCloseBehavior
    用于自动关闭其他已打开的滑动项:
SlidableAutoCloseBehavior(child: yourWidget,
)
  1. ActionPane
    定义滑动操作面板:
ActionPane(motion: ScrollMotion(), // 滑动动画效果children: [SlidableAction(onPressed: (context) {// 处理点击事件},backgroundColor: Colors.red,foregroundColor: Colors.white,icon: Icons.delete,label: 'Delete',),],
)
  1. 滑动方向
    Slidable 支持从左侧或右侧滑动:
    • startActionPane: 从左侧滑动显示
    • endActionPane: 从右侧滑动显示
  2. 状态保持
    结合 AutomaticKeepAliveClientMixin 保持滑动列表状态:
class _KeepAliveListViewState extends State<KeepAliveListView>with AutomaticKeepAliveClientMixin {@overridebool get wantKeepAlive => true;@overrideWidget build(BuildContext context) {super.build(context); // 必须调用}
}

结语

通过本篇文章,相信你已经知道如何使用 flutter_slidable 插件,并轻松实现丰富的滑动交互功能。


感谢您的阅读和参与,HH思无邪愿与您一起在技术的道路上不断探索。如果您喜欢这篇文章,不妨留下您宝贵的赞!如果您对文章有任何疑问或建议,欢迎在评论区留言,我会第一时间处理,您的支持是我前行的动力,愿我们都能成为更好的自己!

相关文章:

  • 精益数据分析(15/126):解锁数据分析关键方法,驱动业务增长
  • 使用Python+OpenCV对视频抽帧保存为JPG图像
  • MongoDB常用命令
  • 【JAVA】十三、基础知识“接口”精细讲解!(二)(新手友好版~)
  • uniapp-商城-33-shop 布局搜索页面以及u-search
  • 云原生--基础篇-3--云原生概述(云、原生、云计算、核心组成、核心特点)
  • 【2025最新Java面试八股】如何理解MySQL的MVCC机制?
  • DeepSeek和Excel结合生成动态图表
  • 「数据可视化 D3系列」入门第十二章:树状图详解与实践
  • K8S探针的应用
  • Rook 部署 Ceph 集群及 Kubernetes 存储对接实战
  • 【微服务】SpringBoot制作Docker镜像接入SkyWalking详解
  • Anaconda 与 Miniconda 的差异详解
  • [论文阅读]ConfusedPilot: Confused Deputy Risks in RAG-based LLMs
  • 树莓派学习专题<8>:使用V4L2驱动获取摄像头数据--获取摄像头支持的分辨率
  • 进行性核上性麻痹饮食指南:科学膳食提升生活质量
  • SQL中函数
  • C# 跨进程 临界区 互斥 进程锁
  • 轻量级景好鼠标录制器
  • 基于javaweb的SSM+Maven小区失物招领系统设计与实现(源码+文档+部署讲解)
  • 长三角铁路今日预计发送旅客398万人次,客流持续保持高位运行
  • 金正恩视察重要坦克厂并强调更迭陆军装备
  • 5名中国公民在美国交通事故中遇难
  • 证监会:坚决拥护党中央对王建军进行纪律审查和监察调查决定
  • 马上评|科学谋划“十五五”,坚定不移办好自己的事
  • 4月人民币对美元即期汇率微跌,今年以来升值0.48%