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.pswp.cn/web/24187.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/24187.shtml
英文地址,請注明出處:http://en.pswp.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;三、壁紙分享…