Flutter Dismissible 属性介绍及使用指南

在移动应用开发中,滑动删除是一种常见的交互方式。Flutter 提供了一个强大的小部件 Dismissible,使得实现这一功能变得非常简单。本文将介绍 Dismissible 的主要属性及其使用方法。

1. Dismissible 简介

Dismissible 是一个 Flutter 小部件,可以包裹其他小部件,使其能够通过滑动手势被删除。常见的用例包括待办事项列表、邮件列表等,在用户滑动某一项时,可以进行删除、归档等操作。

2. Dismissible 的主要属性

  • key: 每个 Dismissible 组件必须提供一个唯一的 key,用于标识该项。
  • child: Dismissible 包裹的子组件,即你想要实现滑动删除功能的组件。
  • background: 在滑动过程中显示的背景组件。通常用于显示删除等操作的提示。
  • secondaryBackground: 从右向左滑动时显示的背景组件。
  • direction: 允许滑动的方向。可以是 DismissDirection.horizontalDismissDirection.verticalDismissDirection.endToStartDismissDirection.startToEnd
  • confirmDismiss: 滑动时的确认回调,可以在这里弹出确认对话框或进行其他判断逻辑。
  • onDismissed: 确认删除后的回调函数。

3. Dismissible 的使用示例

下面是一个简单的示例,展示了如何在一个待办事项列表中使用 Dismissible 实现滑动删除功能。

import 'package:flutter/material.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Dismissible 示例'),),body: TodoList(),),);}
}class TodoList extends StatefulWidget {_TodoListState createState() => _TodoListState();
}class _TodoListState extends State<TodoList> {final List<String> items = List<String>.generate(10, (i) => "待办事项 ${i + 1}");Widget build(BuildContext context) {return ListView.builder(itemCount: items.length,itemBuilder: (context, index) {final item = items[index];return Dismissible(key: Key(item),background: Container(color: Colors.green, child: Icon(Icons.check)),secondaryBackground: Container(color: Colors.red, child: Icon(Icons.delete)),onDismissed: (direction) {setState(() {items.removeAt(index);});ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text("$item 已删除")),);},confirmDismiss: (direction) {return showDialog(context: context,builder: (BuildContext context) {return AlertDialog(title: Text("确认删除"),content: Text("你确定要删除 $item 吗?"),actions: <Widget>[TextButton(onPressed: () => Navigator.of(context).pop(false),child: Text("取消"),),TextButton(onPressed: () => Navigator.of(context).pop(true),child: Text("确认"),),],);},);},child: ListTile(title: Text('$item'),),);},);}
}

4. 代码解析

  • 关键属性解析
    • key: 使用 item 作为每个 Dismissible 项的唯一标识符。
    • backgroundsecondaryBackground: 分别定义滑动方向不同的背景。
    • onDismissed: 当滑动结束并确认删除后,更新状态并显示提示信息。
    • confirmDismiss: 在删除前弹出确认对话框。

5. 总结

Dismissible 小部件使得在 Flutter 中实现滑动删除变得非常方便。通过合理配置其属性,可以实现各种定制化的交互效果。希望这篇文章能够帮助你更好地理解和使用 Dismissible。如果你有任何问题或建议,欢迎在下方留言讨论。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/24187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前后端实现文件上传进度条-实时进度

后端接口代码&#xff1a; PostMapping("/upload")public ResponseEntity<String> handleFileUpload(RequestParam("file") MultipartFile file) {try {// 获取文件名String fileName file.getOriginalFilename();// 创建上传目标路径Path targetPa…

基于简单Agent对医疗数据进行分析

数据表 供应商资格审核规定.pdf 医生名录.xlsx 历史就诊记录.xlsx 患者信息名录.xlsx 药品.xlsx 药品库存管理.xlsx 采购单位基本信息.xlsx Agent测试 模型基于ChatGPT-3.5 问题&#xff1a;帮我找出不达标的供应商 Agent分析过程 [Thought: 0] Key Concepts: - 不达标的供…

P7 品牌管理

逆向生成页面 新增菜单—商品系统的品牌管理 —product/brand 在代码生成器得到的文件中&#xff0c; main-resources-src-views-modules-product brand.vue、brand-add-or-update.vue放到category.vue同级vue文件有新增、删除按钮&#xff0c;但页面未显示&#xff0c;是因…

嵌入式Linux系统中RTC应用的操作详解

第一:RTC的作用以及时间简介 “RTC”的英文全称是Reul-Time Clock,翻译过来是实时时钟芯片.实时时钟芯片是日常生活中应用最为广泛的电子器件之一,它为人们或者电子系统提供精确的实时时间,实时时钟芯片通过引脚对外提供时间读写接口,通常内部带有电池,保证在外部系统关…

【Android】使用EventBus进行线程间通讯

EventBus 简介 EventBus&#xff1a;github EventBus是Android和Java的发布/订阅事件总线。 简化组件之间的通信 解耦事件发送者和接收者 在 Activities, Fragments, background threads中表现良好 避免复杂且容易出错的依赖关系和生命周期问题 Publisher使用post发出…

好书推荐-人工智能数学基础

本书以零基础讲解为宗旨&#xff0c;面向学习数据科学与人工智能的读者&#xff0c;通俗地讲解每一个知识点&#xff0c;旨在帮助读者快速打下数学基础。    全书分为 4 篇&#xff0c;共 17 章。其中第 1 篇为数学知识基础篇&#xff0c;主要讲述了高等数学基础、微积分、泰…

鸿蒙Ability Kit(程序框架服务)【应用启动框架AppStartup】

应用启动框架AppStartup 概述 AppStartup提供了一种更加简单高效的初始化组件的方式&#xff0c;支持异步初始化组件加速应用的启动时间。使用启动框架应用开发者只需要分别为待初始化的组件实现AppStartup提供的[StartupTask]接口&#xff0c;并在[startup_config]中配置App…

Open vSwitch 数据包处理流程

一、Open vSwitch 数据包转发模式 Open vSwitch 根据不同的模块使用&#xff0c;主要分为两种数据包的转发模式&#xff1a;Datapath 模式和 DPDK 模式&#xff0c;这两种模式的主要区别在于&#xff1a; Datapath 模式&#xff1a; 使用内核空间的网络栈进行数据包的转发性能相…

理解和实现 LRU 缓存置换算法

引言 在计算机科学中&#xff0c;缓存是一种用于提高数据访问速度的技术。然而&#xff0c;缓存空间是有限的&#xff0c;当缓存被填满时&#xff0c;就需要一种策略来决定哪些数据应该保留&#xff0c;哪些应该被淘汰。LRU&#xff08;最近最少使用&#xff09;算法是一种广泛…

UML实现图-部署图

概述 部署图(Deployent Diagram)描述了运行软件的系统中硬件和软件的物理结构。部署图中通常包含两种元素:节点和关联关系&#xff0c;部署图中每个配置必须存在于某些节点上。部署图也可以包含包或子系统。 节点是在运行时代表计算机资源的物理元素。节点名称有两种:简单名和…

android studio开发时提示 TLS 握手错误解决办法

我用的是windows&#xff0c;遇到了这错误&#xff0c; The server may not support the clients requested TLS protocol versions: (TLSv1.2, TLSv1.3). You may need to configure the client to allow other protocols to be used. For more on this, please refer to http…

苍穹外卖笔记-08-套餐管理-增加,删除,修改,查询和起售停售套餐

套餐管理 1 任务2 新增套餐2.1 需求分析和设计接口设计setmeal和setmeal_dish表设计 2.2 代码开发2.2.1 根据分类id查询菜品DishControllerDishServiceDishServiceImplDishMapperDishMapper.xml 2.2.2 新增套餐接口SetmealControllerSetmealServiceSetmealServiceImplSetmealMa…

c++替换字符或字符串函数

在C中&#xff0c;有多种方法可以替换字符串或字符。下面是一些常用的方法&#xff1a; 使用replace函数&#xff1a; replace函数可以替换字符串中的指定字符或子字符串。它的用法如下&#xff1a; string str "Hello World"; str.replace(str.find("World&qu…

Nginx03-动态资源和LNMP介绍与实验、自动索引模块、基础认证模块、状态模块

目录 写在前面Nginx03案例1 模拟视频下载网站自动索引autoindex基础认证auth_basic模块状态stub_status模块模块小结 案例2 动态网站&#xff08;部署php代码&#xff09;概述常见的动态网站的架构LNMP架构流程数据库Mariadb安装安全配置基本操作 PHP安装php修改配置文件 Nginx…

AI做的2024年高考数学试卷,答案对吗?

2024年高考数学考试已经结束&#xff0c;现在呈上数学真题及AI给出的解答。供各位看官欣赏。 总的来说&#xff0c;人工做题两小时&#xff0c;AI解答两分钟。 但是&#xff0c;AI做的答案是否正确&#xff0c;那就要各位看官来评判了&#xff01; 注&#xff1a;试卷来源于…

【Linux】另一种基于rpm安装yum的方式

之前的163的镜像源504网关异常了&#xff0c;网上找到的方法基本都是基于apt&#xff0c;或是基于apt-get。找到了大佬帮忙装了一下&#xff0c;记录如下&#xff1a; wget https://vault.centos.org/7.9.2009/os/x86_64/Packages/yum-metadata-parser-1.1.4-10.el7.x86_64.rpm…

2024年5大制作AI电子手册工具推荐

AI电子手册作为一种结合了人工智能技术和传统电子手册功能的新型工具&#xff0c;逐渐成为了企业进行知识管理和信息传递的重要工具&#xff0c;为企业提高效率、优化用户体验。在本文中&#xff0c;LookLook同学将简单介绍一下什么是AI电子手册、对企业有什么好处&#xff0c;…

JAVA面试中,面试官最爱问的问题。

Optional类是什么&#xff1f;它在Java中的用途是什么&#xff1f; Java中的Optional类是一个容器类&#xff0c;它用于封装可能为空的对象。在Java 8之前&#xff0c;空值检查是Java编程中一个常见的问题&#xff0c;尤其是在处理返回单个值的方法时。Optional类提供了一种更…

电源变压器的作用和性能

电源变压器的主要作用是改变输入电压的大小&#xff0c;通常用于降低电压或升高电压&#xff0c;以便适应不同设备的需求。它们还可以提供隔离&#xff0c;使得输出电路与输入电路之间电气隔离&#xff0c;从而提高安全性。性能方面&#xff0c;电源变压器需要具有高效率、低温…

Unity3D测量距离实现方法(一)

系列文章目录 unity工具 文章目录 系列文章目录&#x1f449;前言&#x1f449;一、Unity距离测量1-1 制作预制体1-2 编写测量的脚本 &#x1f449;二、鼠标点击模型进行测量&#x1f449;二、字体面向摄像机的方法&#x1f449;二、最短距离测量方法&#x1f449;三、壁纸分享…