当前位置: 首页 > news >正文

flutter 输入时插入分隔符

每四位插入一个分隔符import 'package:flutter/services.dart';class DividerInputFormatter extends TextInputFormatter {final int rear; //第一个分割位数,后面分割位,,数final String pattern; //分割符DividerInputFormatter({this.rear = 4, this.pattern = ' '});@overrideTextEditingValue formatEditUpdate(TextEditingValue oldValue, TextEditingValue newValue) {//不含分隔符的文本String allTextPure = newValue.text.replaceAll(RegExp(pattern), '');//处理后含分隔符的文本String allTextDeal = '';//光标位置int cursorPosition = newValue.selection.baseOffset;for (int i = 0; i < allTextPure.length; i++) {if ((i > 0 && (i) % rear == 0) && allTextPure[i] != pattern) {allTextDeal = '$allTextDeal$pattern';}allTextDeal += allTextPure[i];}///光标在文字最右侧(尾部)的情况,光标始终在最后if (cursorPosition >= newValue.text.length) {return TextEditingValue(text: allTextDeal,selection: TextSelection.collapsed(offset: allTextDeal.length),);}///光标不在文字尾部的情况//如果原光标位置变为分割符,则说明左侧增加一位,光标也加一位if (allTextDeal.substring(cursorPosition - 1, cursorPosition) == pattern) {cursorPosition++;}return TextEditingValue(text: allTextDeal,selection: TextSelection.collapsed(offset: cursorPosition),);}
}

 手机号规则分隔符


import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

void main() => runApp(MaterialApp(home: DividerFormatterPage()));

class DividerFormatterPage extends StatelessWidget {
  const DividerFormatterPage({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) => Scaffold(body: _buildBody());

  _buildBody() {
    return Padding(
      padding: EdgeInsets.symmetric(horizontal: 15, vertical: 100),
      child: TextField(
        inputFormatters: [
          DividerInputFormatter(pattern: '-'),
          FilteringTextInputFormatter.allow(RegExp(r'[0-9\s\-]')),
          LengthLimitingTextInputFormatter(13),
        ],
      ),
    );
  }
}

class DividerInputFormatter extends TextInputFormatter {
  final int first, rear; //第一个分割位数,后面分割位,,数
  final String pattern; //分割符

  DividerInputFormatter({this.first = 3, this.rear = 4, this.pattern = ' '});

  @override
  TextEditingValue formatEditUpdate(TextEditingValue oldValue, TextEditingValue newValue) {
    //不含分隔符的文本
    String allTextPure = newValue.text.replaceAll(RegExp(pattern), '');
    //处理后含分隔符的文本
    String allTextDeal = '';
    //光标位置
    int cursorPosition = newValue.selection.baseOffset;
    for (int i = 0; i < allTextPure.length; i++) {
      if ((i == first || (i - first) % rear == 0) && allTextPure[i] != pattern) {
        allTextDeal = '$allTextDeal$pattern';
      }
      allTextDeal += allTextPure[i];
    }

    ///光标在文字最右侧(尾部)的情况,光标始终在最后
    if (cursorPosition >= newValue.text.length) {
      return TextEditingValue(
        text: allTextDeal,
        selection: TextSelection.collapsed(offset: allTextDeal.length),
      );
    }

    ///光标不在文字尾部的情况
    //如果原光标位置变为分割符,则说明左侧增加一位,光标也加一位
    if (allTextDeal.substring(cursorPosition - 1, cursorPosition) == pattern) {
      cursorPosition++;
    }
    return TextEditingValue(
      text: allTextDeal,
      selection: TextSelection.collapsed(offset: cursorPosition),
    );
  }
}
 

 

http://www.lryc.cn/news/42423.html

相关文章:

  • 静态版通讯录——“C”
  • 前端基础开发环境搭建工具等
  • 华为OD机试题【IPv4 地址转换成整数】用 Java 解 | 含解题说明
  • [数据结构]排序算法
  • 不愧是2023年就业最难的一年,还好有车企顶着~
  • C/C++之while(do-while)详细讲解
  • SpringCloud学习笔记(一)认识微服务
  • Unity中使用WebSocket (ws://)的方法
  • 米哈游春招算法岗-2023.03.19-第一题-交换字符-简单题
  • 能把爬虫讲的这么透彻的,没有20年功夫还真不行【0基础也能看懂】
  • springcloud学习总结
  • 2022年亏损超10亿,告别野蛮成长的众安在线急需新“引擎”
  • ChatGPT文心一言逻辑大比拼(一)
  • 【机器学习面试总结】————特征工程
  • 如何将字符串反转?
  • Linux内核IO基础知识与概念
  • paper文献和科研小工具
  • dfs和bfs能解决的问题
  • 静态通讯录,适合初学者的手把手一条龙讲解
  • 【你不知道的 CSS】你写的 CSS 太过冗余,以至于我对它下手了
  • Lesson 8.1 决策树的核心思想与建模流程
  • 【算法】FIFO先来先淘汰算法分析和编码实战
  • 二分查找——我欲修仙(功法篇)
  • Python 多线程
  • JVM笔记(九)选择合适的垃圾收集器
  • 二维图像处理到三维点云处理
  • leetcode 删除有序数组中的重复项
  • JVM学习.03 类加载机制
  • Celery使用:优秀的python异步任务框架
  • 第十四届蓝桥杯三月真题刷题训练——第 19 天