Flutter 中的 FilterChip 小部件:全面指南

Flutter 中的 FilterChip 小部件:全面指南

在 Flutter 中,FilterChip 是一種特殊類型的 Chip,用于呈現過濾選項。用戶可以通過點擊 FilterChip 來應用相應的過濾條件,這在需要對列表或集合進行篩選的場景中非常有用,如在電商應用中篩選商品,或在新聞應用中根據類別篩選文章。

基礎用法

FilterChip 最基本的用法是顯示一段文本,并且允許用戶點擊以應用過濾:

FilterChip(label: Text('Basic FilterChip'),onSelected: (bool selected) {// 當 FilterChip 被點擊時執行的操作},
)

自定義樣式

FilterChip 提供了多種屬性來定制其外觀:

背景顏色

  • backgroundColor: 設置 FilterChip 的背景顏色。
FilterChip(label: Text('Colored FilterChip'),backgroundColor: Colors.blue,onSelected: (bool selected) {/* ... */},
)

前景色

  • foregroundColor: 設置 FilterChip 的前景色,如文本顏色。
FilterChip(label: Text('White Text FilterChip'),foregroundColor: Colors.white,backgroundColor: Colors.blue,onSelected: (bool selected) {/* ... */},
)

標簽

  • label: 設置 FilterChip 的標簽,可以是任意的 Widget。
FilterChip(label: Text('Custom Label FilterChip'),onSelected: (bool selected) {/* ... */},
)

選中狀態

  • selected: 定義 FilterChip 是否被選中。
  • onSelected: 設置當 FilterChip 被點擊時的回調。
FilterChip(label: Text('Selectable FilterChip'),selected: true,onSelected: (bool selected) {// 處理選中狀態改變},
)

實例:帶有圖標的 FilterChip

FilterChip 可以包含圖標,例如在標簽的前面或后面:

FilterChip(prefix: Icon(Icons.local_offer), // 前綴圖標label: Text('FilterChip with Icon'),onSelected: (bool selected) {/* ... */},
)

實例:篩選條件

FilterChip 可以用來展示篩選條件,允許用戶通過點擊來選擇或取消選擇:

FilterChip(label: Text('Discounts'),selected: discountsFilterActive, // 假設這是一個布爾值onSelected: (bool value) {// 更新篩選條件的狀態setState(() {discountsFilterActive = value;});},
)

實例:動態 FilterChip

可以動態創建 FilterChip 列表,根據篩選項的數量或用戶的選擇動態添加或移除 FilterChip

List<String> _selectedFilters = [];
Widget build(BuildContext context) {return Wrap(children: filters.map((filter) {return FilterChip(label: Text(filter),selected: _selectedFilters.contains(filter),onSelected: (bool selected) {setState(() {if (selected) {_selectedFilters.add(filter);} else {_selectedFilters.remove(filter);}});},);}).toList(),);
}

結語

FilterChip 是 Flutter 中一個實用的小部件,它提供了一種直觀的方式來展示和操作篩選條件,特別適合用于需要篩選功能的界面。掌握 FilterChip 的使用,可以幫助你創建出既美觀又交互性強的用戶界面,提升應用的用戶體驗。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/11772.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/11772.shtml
英文地址,請注明出處:http://en.pswp.cn/web/11772.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

51單片機實現俄羅斯方塊游戲編程

一、設計要求 &#xff08;1&#xff09;利用51單片機&#xff0c;設計一款俄羅斯方塊游戲&#xff0c;完成硬件電路的開發和程序的編寫調試&#xff1b; &#xff08;2&#xff09;采用LCD12864液晶作為游戲運行界面&#xff1b; &#xff08;3&#xff09;利用按鍵輸入靈活…

Spring Boot集成dubbo快速入門Demo

1.什么是dubbo&#xff1f; Apache Dubbo 是一款微服務開發框架&#xff0c;它提供了 RPC通信 與 微服務治理 兩大關鍵能力。這意味著&#xff0c;使用 Dubbo 開發的微服務&#xff0c;將具備相互之間的遠程發現與通信能力&#xff0c; 同時利用 Dubbo 提供的豐富服務治理能力…

HTML飄落的花瓣

目錄 寫在前面 HTML???????簡介 完整代碼 代碼分析 系列推薦 寫在最后 寫在前面 本期小編給大家推薦HTML實現的飄落的花瓣&#xff0c;無需安裝軟件&#xff0c;直接下載即可打開~ HTML???????簡介 HTML&#xff08;Hypertext Markup Language&#xff…

探索Playwright:Python下的Web自動化測試革命

在如今這個互聯網技術迅速發展的時代&#xff0c;web應用的質量直接關系著企業的聲譽和用戶的體驗。因此&#xff0c;自動化測試成為了保障軟件質量的重要手段之一。今天&#xff0c;我將帶大家詳細了解一款在測試領域大放異彩的神器——Playwright&#xff0c;并通過Python語言…

一覺醒來 AI科技圈發生的大小事兒 05月13日

&#x1f4f3;博弈論讓 AI 更加正確、高效&#xff0c;LLM 與自己競爭 研究團隊設計了共識博弈&#xff0c;通過讓語言模型的生成器和判別器相互博弈來提高模型的準確性和內部一致性。這種方法不需要對基礎模型進行訓練或修改&#xff0c;可以在筆記本電腦上快速執行。研究結果…

基于微信小程序+JAVA Springboot 實現的【停車場小程序】app+后臺管理系統 (內附設計LW + PPT+ 源碼+ 演示視頻 下載)

項目名稱 項目名稱&#xff1a; 停車場微信小程序的設計與實現 在當前信息技術飛速發展的背景下&#xff0c;停車場微信小程序的開發成為了一個創新的解決方案&#xff0c;旨在提高停車場管理的效率和用戶的停車體驗。本項目通過深入分析現有停車場管理系統的不足&#xff0c…

內存屏障 - LINUX KERNEL MEMORY BARRIERS 上 與 下

內存屏障&#xff08;Memory Barrier&#xff09;是在計算機體系結構中使用的一種同步機制&#xff0c;用于確保在多線程或多核處理器環境中&#xff0c;對共享內存的操作按照預期順序進行。它們通過強制在特定點執行一些指令來規定內存訪問的順序&#xff0c;并防止內存亂序執…

弱網對抗的策略有哪些?

在弱網環境下&#xff0c;數據傳輸可能會面臨丟包、延遲、抖動等問題&#xff0c;因此采取合適的弱網對抗策略對于確保數據傳輸的穩定性和可靠性至關重要。以下是一些常見的弱網對抗策略&#xff1a; 數據壓縮&#xff1a;使用壓縮算法如Gzip、Brotli等對數據進行壓縮&#xf…

Linux-vi/vim

vi是一個文本編輯器&#xff0c;用于撰寫文檔或開發程序 vim是vi的增強版&#xff0c;功能一致&#xff0c;可視化效果更好一些&#xff0c;去鼠標化&#xff0c;編輯更加方便&#xff0c;可定制化 vim編輯器是一個模式化文本編輯工具 vim有三種模式 編輯模式、插入模式和末…

使用PageHelper分頁插件,發現獲取到的total總記錄數量不對,無法獲取到正確的total數量

目錄 1.1、錯誤描述 1.2、解決方案 1.1、錯誤描述 周一在工作中&#xff0c;寫了一個列表分頁的接口&#xff0c;其中使用的是PageHelper分頁依賴&#xff0c;原本想著挺簡單的&#xff0c;也就是使用PageHelper.startPage(pageNum, pageSize);方法就可以了&#xff0c;代碼…

Linux下COOLFluiD源碼編譯安裝及使用

目錄 軟件介紹 基本依賴 其它可選依賴 一、源碼下載 二、解壓縮&#xff08;通過Github下載zip壓縮包格式&#xff09; 三、編譯安裝 3.1 依賴項-BOOST 3.2 依賴項-Parmetis 3.3 依賴項-PETSc 3.4 安裝COOLFluiD 四、算例運行 軟件介紹 COOLFluiD&#xff08;面向對象…

學術共振 美妙發聲 | 2024美沃斯大會完美收官,米蘭柏羽傾力承辦

5月10日-5月12日&#xff0c;為期3天的第十七屆美沃斯醫療美容大會在杭州國際博覽中心盛大舉辦&#xff0c;作為行業頂級學術交流平臺&#xff0c;本屆美沃斯大會不僅是醫美行業的一次學術交流盛會&#xff0c;更是一次深度探討行業未來的遠眺之窗。 5月9日&#xff0c;即美沃…

golang中switch-case及select-cas

switch a{ case b: 執行內容b case c: 執行內容c } golang中case后自帶break跳出功能&#xff0c;既&#xff1a;滿足case b 執行內容b后自動跳出&#xff0c;不會去走case c select { case <- ch1: 執行內容b case -<ch2: 執行內容c default: fmt.Println("chan…

定時備份docker-MySQL中的所有數據庫

backup_mysql.sh #!/bin/bash# 設置備份存儲目錄 backup_dir"/docker/hunqingyun-docker/mysql/backup"# 設置 MySQL 容器名稱和備份文件名 mysql_container"ruoyi-mysql" backup_file"$backup_dir/$(date %Y%m%d%H%M%S).sql"# MySQL root 用戶…

vue-router路由,帶參數的動態路由匹配(2024-05-14)

需求 需要將給定匹配模式的路由映射到同一個組件。例如&#xff0c;我們可能有一個 User 組件&#xff0c;它應該對所有用戶進行渲染&#xff0c;但用戶 ID 不同。在 Vue Router 中&#xff0c;我們可以在路徑中使用一個動態字段來實現&#xff0c;我們稱之為 路徑參數 &#…

添磚Java之路(其五)——封裝,String,StringBuilder類。

封裝&#xff1a; 封裝意義&#xff1a;更好的維護數據&#xff0c;讓使用者無需關心如何使用&#xff0c;只需要知道怎么使用。 Java Bean&#xff1a; 然后我們要知道Java Bean(實體類)標準。 1.對于這個類的成員都需要設為私有&#xff0c;而且要對外提供相應Get,Set的接…

組合商標申請如何風控提高通過率!

最近一個老客戶找到普推知產老楊&#xff0c;說要申請注冊一個新的商標&#xff0c;是一個組合商標&#xff0c;有圖形&#xff0c;兩行文字&#xff0c;一行文字的拼音&#xff0c;還有三個字母的簡稱&#xff0c;組合商標在申請時會進行拆分審查&#xff0c;圖形、文字、拼音…

【C++初階】第十一站:list的介紹及使用

目錄 list的介紹及使用 1.list的含義 2.list的介紹 3.list的使用 1.list的構造 2.list iterator的使用 3.list capacity 4.list element access 5 list modifiers 尾插尾刪 和 頭插頭刪 insert 和 erase resize swap clear 6.list sort and reverse 7.list copy vector copy li…

Java身份證識別接口集成開發示例,身份證查詢接口

人類是有情感的&#xff0c;人們所接觸到的各種事物和信息都會被身體相應器官所接收&#xff0c;然后通過神經元傳入大腦繼而被識別&#xff0c;然后大腦便會產生對該事物的認知和情緒。人們大多喜歡熱情、有趣的事物&#xff0c;對冷冰冰、枯燥、無趣的APP基本是提不起興趣的。…

16.Set、泛型、枚舉、反射、Class

Set Set集合是Collection集合的子接口&#xff0c;元素不能重復&#xff0c;只能有一個null&#xff0c;元素存放無序。 常用子類 HashSet TreeSet LinkedHashSet HashSet 其實底層就是HashMap&#xff0c;當我們構造一個HashSet對象&#xff0c;就是在 new HashSet(); …