flutter3.7.12版本设置TextField的contextMenuBuilder的文字颜色

线上版本用的是flutter3.7.12,报了个bug,TextField长按后弹出一个空白框。

这个空白框点击是有事件的,很离奇,但是得解决。

首先看了看源码,TextField原本的属性toolbarOptions已过时,推荐使用contextMenuBuilder设置,就找了一下contextMenuBuilder的用法,普遍是以下代码

复制代码
TextField(
  contextMenuBuilder: (BuildContext context, EditableTextState editableTextState) {
    return AdaptiveTextSelectionToolbar.buttonItems(
      anchors: editableTextState.contextMenuAnchors,
      buttonItems: editableTextState.contextMenuButtonItems.map((item) {
        return ContextMenuButtonItem(
          onPressed: item.onPressed,
          label: Text(
            item.label,
            style: const TextStyle(color: Colors.red), // 改这里
          ),
        );
      }).toList(),
    );
  },
)

但是报错,3.7.12版本的lable只支持String,不支持Text。难道要更新版?

于是询问了chapt改为如下表达

复制代码
 var items = editableTextState.contextMenuButtonItems;

  return AdaptiveTextSelectionToolbar(
        anchors: editableTextState.contextMenuAnchors,
        children: items.map((ContextMenuButtonItem item) {
          return TextButton(
            onPressed: item.onPressed,
            child: Text(item.lable,
              style:  TextStyle(color: BaseColors.textBlack_1b), // 自定义颜色
            ),
          );
        }).toList(),
      );

跑通了,但是问题并没有被解决,经过测试发现 item.lable=null,那事件是怎么完成的呢?ContextMenuButtonItem内部有三个参数:onPressed,type,label。可以看到除了lable之外其他两个参数都有值,所以文字显示不出来是因为文字不存在。

于是做了个switch判断将ContextMenuButtonType枚举的所有类型都换成文字,解决了。

相关推荐
前端若水3 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger3 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)4 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态4 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态4 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart4 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe54 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒6 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu6 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿6 小时前
Spring Boot自动配置详解
java·大数据·前端