IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Flutter 防止TextFiled Form表单validator时红字出来时会撑一下布局 -> 正文阅读

[移动开发]Flutter 防止TextFiled Form表单validator时红字出来时会撑一下布局

当输入内容报错后 TextFiled会自动展示红字报错,但是红字出来时会撑一下布局,修改方法TextFiled增加 errorText: “”,这里的意思是errorText提前占位,只不过内容是空字符,但是写上errorText时会发现红字时底线也变红,不想边线变红可以如下修改方法

       focusedErrorBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: primaryColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),
              errorBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: lineColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),

完整代码



typedef void OnValueChanged(String value);
typedef void VisibleClick();

class LoginTextFiled extends StatelessWidget {
  final bool pswVisible;
  final VisibleClick visibleClick;
  final String hintText;

  final TextEditingController controller;
  final OnValueChanged onValueChanged;
  final FocusNode focusNode;
  final ShakeAnimationController animationController;
  final Function onClear;
  final TextInputAction textInputAction;
  final TextInputType textInputType;
  final bool isVisibleSuffixText;
  final String leftText;
  final bool isPhoneNumber;
  final FormFieldValidator<String> validator;

  final ValueChanged<String> onFieldSubmitted;

  const LoginTextFiled(
      {Key key,
      this.controller,
      this.onValueChanged,
      this.pswVisible = true,
      this.visibleClick,
      this.hintText,
      this.animationController,
      this.focusNode,
      this.onClear,
      this.textInputAction,
      this.textInputType,
      this.isVisibleSuffixText = false,
      this.leftText,
      this.isPhoneNumber = false,
      this.validator,
      this.onFieldSubmitted})
      : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Container(
        child: ShakeAnimation(
      TextFormField(
          onFieldSubmitted: onFieldSubmitted,
          validator: validator,
          autovalidateMode: AutovalidateMode.onUserInteraction,
          style: t14blackblod,
          textInputAction: textInputAction,
          keyboardType: isPhoneNumber
              ? TextInputType.number
              : TextInputType.visiblePassword,
          obscureText: pswVisible,
          inputFormatters: isPhoneNumber
              ? [
                  LengthLimitingTextInputFormatter(11),
                  FilteringTextInputFormatter.allow(RegExp('[0-9]'))
                ]
              : [
                  LengthLimitingTextInputFormatter(20),
                ],
          controller: controller,
          focusNode: focusNode ?? FocusNode(),
          onChanged: (text) {
            if (onValueChanged != null) {
              onValueChanged(text);
            }
          },
          decoration: InputDecoration(
              prefixIcon: Visibility(
                  visible: isVisibleSuffixText,
                  child: Padding(
                      padding: EdgeInsets.only(right: 10, bottom: 3),
                      child: Text(
                        leftText ?? "",
                        style: t14blackSemiblod,
                      ))),
              prefixIconConstraints: BoxConstraints(),
              suffixIcon: Row(
                mainAxisSize: MainAxisSize.min,
                mainAxisAlignment: MainAxisAlignment.end,
                crossAxisAlignment: CrossAxisAlignment.center,
                children: [
                  controller.text == null || controller.text == ''
                      ? Container()
                      : GestureDetector(
                          child: Container(
                            child: Image.asset(
                              'assets/images/clear_icon.png',
                              width: 14,
                              height: 14,
                            ),
                          ),
                          onTap: () {
                            controller.text = '';
                            onClear();
                          },
                        ),
                  Visibility(
                      visible: !isPhoneNumber,
                      child: SizedBox(
                        width: 10,
                      )),
                  Visibility(
                      visible: !isPhoneNumber,
                      child: GestureDetector(
                        child: Container(
                          width: 15,
                          height: 15,
                          child: Image.asset(pswVisible
                              ? 'assets/images/close_eye.png'
                              : 'assets/images/open_eye.png'),
                        ),
                        onTap: () {
                          if (visibleClick != null) {
                            visibleClick();
                          }
                        },
                      )),
                ],
              ),
              fillColor: Colors.white,
              hintStyle: t14hintText,
              enabledBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: lineColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),
              focusedBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: primaryColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),
              hintText: '${hintText ?? '${S.of(context).input_psw_tips}'}',
              focusedErrorBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: primaryColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),
              errorBorder: UnderlineInputBorder(
                  borderSide: BorderSide(
                    color: lineColor,
                    width: 2,
                  ),
                  borderRadius: BorderRadius.circular(2)),
              errorText: "",
              errorStyle: t12ErrorRed,
              filled: false,
              counterText: '')),
      animationController,
    ));
  }
}

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-09-09 11:53:22  更:2021-09-09 11:55:28 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 17:20:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码