Forui 0.11.0 版本深度解析:现代化UI组件库的重大升级
项目简介
Forui 是一个现代化的Flutter UI组件库,专注于提供高质量、可定制化的界面元素。它采用了最新的Flutter特性,为开发者提供了丰富的组件集合和灵活的样式系统。本次0.11.0版本带来了多项重大改进,包括样式系统的重构、语义标签的统一、多个核心组件的增强以及新组件的引入。
样式系统全面升级
Forui 0.11.0版本最显著的改进之一是样式系统的全面重构。开发团队引入了一个全新的CLI工具,专门用于生成Forui组件的样式配置,这大大提升了开发效率。
在样式命名方面,团队进行了统一调整:
- 将
FThemeData.colorScheme
重命名为FThemeData.colors
- 将所有
F<Style>.inherit(colorScheme: ...)
方法重命名为F<Style>.inherit(colors: ...)
这些变更虽然带来了短暂的适应成本,但使得API更加一致和直观。更重要的是,所有样式现在都使用WidgetState
系统,提供了更强大的自定义能力和更简洁的配置方式。
语义标签统一化
在之前的版本中,semanticsLabel
和semanticLabel
两种写法并存,给开发者带来了困惑。0.11.0版本彻底解决了这个问题,统一使用semanticsLabel
作为标准命名。这一变更影响了包括FAvatar
、FBreadcrumb
、FCheckbox
、FDialog
等在内的多个组件。
核心组件增强
1. FAccordion改进
FAccordion
组件现在引入了FAccordionItemMixin
,使得自定义折叠项更加灵活。同时,API也进行了调整:
- 将
items
属性重命名为children
- 将
children
的类型从List<FAccordionItem>
改为List<FAccordionItemMixin>
2. FBottomNavigationBar重构
底部导航栏组件进行了重要重构,将可点击逻辑从FBottomNavigationBar
移到了FBottomNavigationBarItem
中。这一变化虽然要求自定义导航项需要自行实现FTappable
,但带来了更好的组件隔离性和可重用性。
新增功能包括:
- 自动聚焦(
autofocus
) - 焦点节点(
focusNode
) - 焦点变化回调(
onFocusChange
) - 悬停状态回调(
onHoverChange
) - 状态变化回调(
onStateChange
) - 项间距(
spacing
)
3. FButton功能扩展
按钮组件新增了多项实用功能:
- 状态变化回调(
onChange
) - 悬停状态回调(
onHoverChange
) - 选中状态(
selected
) - 固有宽度(
intrinsicWidth
)
同时,label
参数被更通用的child
所取代,提高了组件的灵活性。
4. FDialog优化
对话框组件进行了多项优化:
- 不再自动包裹操作按钮和内容在
IntrinsicWidth
中 - 动画参数移入样式类
- 宽度约束整合为统一的
constraints
参数 - 修复了无限尺寸内容的处理问题
5. FHeader改进
头部组件进行了API调整:
actions
重命名为suffixes
prefixActions
重命名为prefixes
suffixActions
重命名为suffixes
- 新增
titleAlignment
参数用于嵌套标题对齐
图标系统重构
0.11.0版本移除了FIcon
组件,转而推荐使用Flutter原生的Icon
类。这一变化主要是为了:
- 支持多色图标
- 统一图标处理方式
- 简化API
同时,所有iconColor
和iconSize
样式属性都被替换为Flutter标准的IconThemeData
,使得图标样式配置更加一致。
新增FSelect组件
本次版本引入了一个全新的FSelect
组件,用于显示可搜索的选择列表。它支持:
- 同步和异步数据加载
- 自定义搜索逻辑
- 灵活的选项渲染
配合新增的FSelectController
,开发者可以完全控制选择行为。
选择组重构
FSelectGroupController
被更通用的FMultiValueNotifier
取代,这一变化使得选择逻辑可以复用于其他非选择组组件。同时新增了:
onChange
回调onSelect
回调- 类型定义简化
表单字段改进
表单相关组件进行了多项增强:
FTextField
拆分为FTextField
和FTextFormField
- 新增
FTextFormField
专门处理表单逻辑 - 修复了多个组件初始值设置问题
- 新增
obscuringCharacter
和filled
等实用属性
可点击组件增强
FTappable
组件进行了重大重构:
- 默认支持动画
- 拆分
hovered
状态为hovered
和pressed
- 新增样式类
FTappableStyle
- 改进状态管理
- 修复动画生命周期问题
其他重要改进
FPortal
重新实现,支持尺寸对齐和方向间距FProgress
支持不确定进度FSlider
新增初始选择和变化回调FTabs
改进滚动行为FTile
新增悬停和状态回调- 新增
FLerpBorderRadius
工具类
总结
Forui 0.11.0版本是一次全面的升级,带来了更一致的API设计、更强大的自定义能力和更丰富的组件功能。虽然包含了一些破坏性变更,但这些改进为未来的发展奠定了更坚实的基础。对于现有项目,建议仔细阅读迁移指南,逐步适配新版本。对于新项目,0.11.0版本提供了现代化、功能丰富的UI解决方案,值得尝试。
- DDeepSeek-V3.1-BaseDeepSeek-V3.1 是一款支持思考模式与非思考模式的混合模型Python00
- QQwen-Image-Edit基于200亿参数Qwen-Image构建,Qwen-Image-Edit实现精准文本渲染与图像编辑,融合语义与外观控制能力Jinja00
GitCode-文心大模型-智源研究院AI应用开发大赛
GitCode&文心大模型&智源研究院强强联合,发起的AI应用开发大赛;总奖池8W,单人最高可得价值3W奖励。快来参加吧~052CommonUtilLibrary
快速开发工具类收集,史上最全的开发工具类,欢迎Follow、Fork、StarJava04GitCode百大开源项目
GitCode百大计划旨在表彰GitCode平台上积极推动项目社区化,拥有广泛影响力的G-Star项目,入选项目不仅代表了GitCode开源生态的蓬勃发展,也反映了当下开源行业的发展趋势。06GOT-OCR-2.0-hf
阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!C0331- WWan2.2-S2V-14B【Wan2.2 全新发布|更强画质,更快生成】新一代视频生成模型 Wan2.2,创新采用MoE架构,实现电影级美学与复杂运动控制,支持720P高清文本/图像生成视频,消费级显卡即可流畅运行,性能达业界领先水平Python00
- GGLM-4.5-AirGLM-4.5 系列模型是专为智能体设计的基础模型。GLM-4.5拥有 3550 亿总参数量,其中 320 亿活跃参数;GLM-4.5-Air采用更紧凑的设计,拥有 1060 亿总参数量,其中 120 亿活跃参数。GLM-4.5模型统一了推理、编码和智能体能力,以满足智能体应用的复杂需求Jinja00
Yi-Coder
Yi Coder 编程模型,小而强大的编程助手HTML013
热门内容推荐
最新内容推荐
项目优选









