芯片
芯片是表示属性、文本、实体或操作的紧凑元素。
芯片帮助人们输入信息、做出选择、过滤内容或触发操作。使用芯片来显示特定上下文中的选项。
示例
辅助芯片
辅助芯片是带有 leading
图标和 on_click
事件的芯片。它们表示在UI中动态和上下文相关出现的智能或自动操作。
辅助芯片的替代选择是按钮,按钮应始终显示并保持一致。
- Python
import flet as ft
def main(page: ft.Page):
def save_to_favorites_clicked(e):
e.control.label.value = "已保存到收藏夹"
e.control.leading = ft.Icon(ft.Icons.FAVORITE_OUTLINED)
e.control.disabled = True
page.update()
def open_google_maps(e):
page.launch_url("https://maps.google.com")
page.update()
save_to_favourites = ft.Chip(
label=ft.Text("保存到收藏夹"),
leading=ft.Icon(ft.Icons.FAVORITE_BORDER_OUTLINED),
bgcolor=ft.Colors.GREEN_200,
disabled_color=ft.Colors.GREEN_100,
autofocus=True,
on_click=save_to_favorites_clicked,
)
open_in_maps = ft.Chip(
label=ft.Text("步行9分钟"),
leading=ft.Icon(ft.Icons.MAP_SHARP),
bgcolor=ft.Colors.GREEN_200,
on_click=open_google_maps,
)
page.add(ft.Row([save_to_favourites, open_in_maps]))
ft.app(target=main)
筛选芯片
筛选芯片是带有 on_select
事件的芯片。它们使用 label
中提供的标签或描述性词语来过滤内容。它们可以是开关或复选框的良好替代品。
- Python
import flet as ft
def main(page: ft.Page):
def amenity_selected(e):
page.update()
title = ft.Row([ft.Icon(ft.Icons.HOTEL_CLASS), ft.Text("设施")])
amenities = ["洗衣机/烘干机", "坡道通道", "允许狗", "允许猫", "无烟"]
amenity_chips = []
for amenity in amenities:
amenity_chips.append(
ft.Chip(
label=ft.Text(amenity),
bgcolor=ft.Colors.GREEN_200,
disabled_color=ft.Colors.GREEN_100,
autofocus=True,
on_select=amenity_selected,
)
)
page.add(title, ft.Row(amenity_chips))
ft.app(target=main)
属性
autofocus
如果控件将被选为初始焦点,则为真。如果页面上有多个控件设置了自动对焦,则第一个添加到页面的控件将获得焦点。
bgcolor
用于未选中、启用的芯片背景的颜色。
border_side
定义芯片轮廓的颜色和宽度。值是BorderSide
类的实例。
check_color
显示勾号时芯片勾号的颜色。
click_elevation
定义点击/按压时芯片的阴影大小的非负值。默认为8.0
。
clip_behavior
根据此选项,内容将被剪切(或不剪切)。属性值是ClipBehavior
。
默认值为ClipBehavior.NONE
。
color
在各种ControlState
中填充芯片的颜色。