【Flutter Utils 全网最齐全的工具类】别裁伪体亲风雅,转益多师是汝师。这篇文章主要讲述Flutter Utils 全网最齐全的工具类相关的知识,希望能为你提供帮助。
FlutterUtils
目录介绍
- 01.事件通知bus工具类
- 02.颜色Color工具类
- 03.日期转化工具类
- 04.File文件工具类
- 05.Sql数据库工具类
- 06.Json转化工具类
- 07.Log日志打印工具类
- 08.屏幕参数工具类
- 09.Sp轻量存储工具类
- 10.辅助计算工具类
- 11.加密和解密工具类
- 12.Num格式处理工具类
- 13.设备参数获取工具类
- 14.图片处理工具类
- 15.网络处理工具类
- 16.常用正则工具类
- 17.Object常用工具类
- 18.验证相关工具类
- 19.路由管理工具类
- 20.Bus事件工具类
- 21.Text文本工具类
- 22.i18拓展工具类
- 23.Time时间工具类
- 24.SPI帮助工具类
- 25.计时器辅助工具类
- 26.常见拓展工具类
- 27.内存缓存工具类
- 28.清除操作工具类
- 29.编解码相关工具类
- 30.反射相关工具类
- 31.资源相关工具类
- 32.Snackbar工具类
- 33.转化相关工具类
- 34.全局异常捕获工具
- 35.解析数据工具类
- 36.字节转化工具类
- 40.其他相关工具类
- 该库地址:https://github.com/yangchong211/YCFlutterUtils
工具类 | 功能说明 |
---|---|
EventBusService | bus事件通知工具类,实现了订阅者模式。用于组件之间通信 |
CalculateUtils | 计算文本的宽,高 |
ColorUtils | 主要是将RGB/ARGB转化为16进制字符串颜色或者Color |
DateFormats | 常见中文,英文的日期时间转化的格式。包含绝大多数的日期格式 |
DateUtils | 日期工具类,获取日期时间,各种时间之间的转换操作 |
EncryptUtils | 加解密工具类,主要是md5加密,base64加密和解密,异或加解密等 |
ExtensionXxx | 拓展类,包含int,list,map,set,num,string等拓展类,有大多数常见操作方法 |
TransformUtils | 转化工具类,包含int,string转化二进制,字母大小写转化等等 |
ValidatorUtils | 校验工具类,包含常见类型,图片,url,邮箱,电话,资源文件,驼峰命名等校验 |
ExtensionXxx | 拓展类,包含int,list,map,set,num,string等拓展类,有大多数常见操作方法 |
TransformUtils | 转化工具类,包含int,string转化二进制,字母大小写转化等等 |
FileUtils | 文件缓存类,主要是存储和获取字符串,Map,Json等数据,写到本地file文件 |
TransformUtils | 转化工具类,包含int,string转化二进制,字母大小写转化等等 |
AppLocalizations | i18相关,可以设置locale,获取语言中字符串 |
ImageUtils | 图片工具类,主要是负责图片和base64转化,加载网络图片,切换圆角,圆形等 |
JsonUtils | json转化工具类,主要是负责list,map,对象和json之间转化等 |
get_it | spi接口实现,将接口(抽象基类)与具体实现分离和解耦合 |
LogUtils | 日志工具类,设置日志开关,长度,以及可以过滤标签,打印5种类型日志 |
NumUtils | Num格式工具类,主要是负责num相关处理和转化操作 |
ObjectUtils | Object超类工具类,负责各种对象判断,获取长度等操作 |
RegexConstants | 常见正则表达式的规则常量,这部分主要参考androidUtils |
RegexUtils | 正则表达式工具类,主要是电话,身份证,邮箱,ip,网络等校验 |
ScreenUtils | 屏幕工具类,获取屏幕的宽高,以及像素密度比等 |
SpUtils | sp存储工具类,适合存储轻量级数据,不建议存储json长字符串 |
TextUtils | 文本工具类,主要处理字符串缩略,*,比较,移除等操作 |
TimerUtils | 倒计时器工具类,设置倒计时总时间,间隔时间,开始暂停等 |
UrlUtils | url工具类,获取url的host,参数,校验等操作 |
SystemUtils | 系统工具类,复制内容到剪切板,弹出和关闭软键盘,清除数据等 |
OtherUtils | RandomUtils随机工具类,SnackUtils,PlatformUtils平台工具类 |
MVP | Flutter版本的MVP架构模版,待完善中…… |
- 具体文档可以demo
- 事件总线
- 通常实现了订阅者模式,订阅者模式包含发布者和订阅者两种角色。
- 第一种方式:使用map集合存储key为事件eventName,value为EventCallback实现bus
//注册监听bus _subscription = EventBusService.instance.eventBus.on< EventMessage> ().listen((event) { String name = event.eventName; //前后台切换发生了变化 if (name == "eventBus1") { var busMessage = event.arguments["busMessage"]; setState(() { message1 = busMessage; }); } }); //发送消息 EventBusService.instance.eventBus.fire(EventMessage( "eventBus1", arguments: {"busMessage": "发送bus消息1"}, )); //页面销毁清除bus if (_subscription != null) { _subscription.cancel(); _subscription = null; }
- 第二种方式:使用StreamController实现bus事件通知
//注册监听消息 bus.on("eventBus2", (arg) { var busMessage = arg; setState(() { message2 = "接收消息:" + busMessage; }); }); //发送消息 var arg = "发送bus消息1"; bus.emit("eventBus2", arg); //移除消息 bus.off("eventBus2", (arg) {});
- 颜色Color工具类。主要是将RGB或者ARGB颜色转化为Color对象,16进制颜色字符串等等。
hexToColor: 将#A357D6颜色转化为16进制的Color toColor: 将#FF6325颜色或者#50A357D6转化为16进制的Color colorString: 将color颜色转变为字符串 colorString: 检查字符串是否为十六进制
- 日期转化工具类。主要是获取当前日期,按指定格式格式化时间,以及多种格式化日期工具方法
getNowDateTime: 获取当前日期返回DateTime getYesterday: 获取昨天日期返回DateTime getNowUtcDateTime: 获取当前日期返回DateTime(utc) getNowDateTimeFormat: 获取当前日期,返回指定格式 getUtcDateTimeFormat: 获取当前日期,返回指定格式 isYesterday: 根据时间判断是否是昨天 getNowDateMs: 将#获取当前毫秒值,返回int getNowDateString: 获取现在日期字符串,默认是:yyyy-MM-dd HH:mm:ss,返回字符串 formatDate: 格式化时间,第一个字段是dateTime,第二个可选项表示格式 formatDateString: 格式化日期字符串,第一个字段例如:\'2021-07-18 16:03:10\',第二个字段例如:"yyyy/M/d HH:mm:ss" formatDateMilliseconds: 格式化日期毫秒时间,第一个字段例如:1213423143312,第二个字段例如:"yyyy/M/d HH:mm:ss" getWeekday: 获取dateTime是星期几 getWeekdayByMilliseconds: 获取毫秒值对应是星期几 isToday: 根据时间戳判断是否是今天 isYesterday: 根据时间判断是否是昨天
4.1 文件存储工具类
- 文件存储工具类。主要是存储和获取String,Json等文件,这个是存储到file本地文件
getTempDir: 获取一个临时目录(缓存),系统可以随时清除 getAppDocDir: 获取应用程序的目录,用于存储只有它可以访问的文件。只有当应用程序被删除时,系统才会清除目录。 getAppFile: 初始化文件路径,默认选中应用程序的目录 readStringDir: 获取存在文件中的数据,默认读到应用程序的目录 writeJsonFileDir: 写入json文件,默认写到应用程序的目录 writeStringDir: 利用文件存储字符串,默认写到应用程序的目录 clearFileDataDir: 清除缓存数据 deleteFileDataDir: 删除缓存文件 writeJsonCustomFile: 写入json文件,自定义路径 writeStringFile: 利用文件存储字符串,自定义路径 readStringCustomFile: 获取自定义路径文件存中的数据
- 文件管理工具类。主要是创建不同的目录路径,创建文件,或者目录路径等操作。
getTempPath: 获取设备上临时目录的路径,该目录没有备份,适合存储下载文件的缓存。 getAppDocPath: 获取应用程序的目录,用于存储只有它可以访问的文件。只有当应用程序被删除时,系统才会清除目录。 getStoragePath: 应用程序可以访问顶层存储的目录的路径 createDirSync: 异步创建文件 createDir: 同步创建文件 createTempDir: 创建临时目录 createAppDocDir: 创建获取应用程序的目录
- 待完善
- Json转化工具类。json转化常见的操作,逐步完善list,map和json字符串互转等。
printJson: 单纯的Json格式输出打印 printJsonEncode: 单纯的Json格式输出打印 encodeObj: 将对象[值]转换为JSON字符串 getObj: 转换JSON字符串到对象 getObject: 转换JSON字符串或JSON映射[源]到对象 getObjList: 转换JSON字符串列表[源]到对象列表 getObjectList: 转换JSON字符串或JSON映射列表[源]到对象列表
- Log日志打印工具类。五种不同类型日志,还可以添加tag标签过滤。
init: 初始化日志,自定义tag,是否是debug环境,日志最大长度,这几个字段都是非必选 d: 打印debug日志 e: 打印error日志 v: 打印v日志 i: 打印info日志 w: 打印ware警告日志
- 屏幕参数工具类。获取屏幕的宽,高,像素密度,状态栏等属性。后期完善适配工作……
screenWidthDp: 当前设备宽度 dp screenHeightDp: 当前设备高度 dp pixelRatio: 设备的像素密度 screenWidth: 当前设备宽度 px = dp * 密度 screenHeight: 当前设备高度 px = dp * 密度statusBarHeight: 状态栏高度 dp 刘海屏会更高 bottomBarHeight: 底部安全区距离 dp textScaleFactory: 像素的字体像素数,字体的缩放比例
- sp轻量级存储工具。主要是sp存储和获取int,String,list,map等数据操作。
init: 初始化,必须要初始化 hasKey: 判断是否存在key的数据 putObject: 存储object类型数据 getObject: 获取sp中key的map数据 putObjectList: 存储sp中key的list集合 getObjectList: 获取sp中key的list集合 getString: 获取sp中key的字符串 putString: 存储sp中key的字符串 getBool: 获取sp中key的布尔值 putBool: 存储sp中key的布尔值 getInt: 获取sp中key的int值 putInt: 存储sp中key的int值 getDouble: 获取sp中key的double值 putDouble: 存储sp中key的double值 getStringList: 获取sp中key的list< String> 值 putStringList: 存储sp中key的list< String> 值 getStringMap: 获取sp中key的map值 putStringMap: 存储sp中key的map值 getDynamic: 获取sp中key的dynamic值 getKeys: 获取sp中所有的key remove: 移除sp中key的值 clear: 清除sp isInitialized: 检查初始化 forEach: 遍历打印sp的key和value
- 加密和解密工具类。目前支持base64加解密,md5加密。后期逐步完善更多加密方法……
encodeMd5: md5 加密字符串,这种是不可逆的 encodeBase64: Base64加密字符串 decodeBase64: Base64解密字符串 xorBase64Encode: 异或对称 Base64 加密 xorBase64Decode: 异或对称 Base64 解密
- 格式处理工具类。主要是处理num格式转化相关操作。
isNum: 检查字符串是int还是double getIntByValueString: 将数字字符串转int。如果字符串不是数字,则转化为0 getDoubleByValueString: 数字字符串转double。如果字符串不是数字,则转化为0 getNumByValueString: 将数字字符串转num,数字保留x位小数 getNumByValueDouble: 浮点数字保留x位小数 addNum: 两个数相加(防止精度丢失) subtractNum: 两个数相减(防止精度丢失) multiplyNum: 两个数相乘(防止精度丢失) divideNum: 两个数相除(防止精度丢失) addDecString: 两个数相加(防止精度丢失) subtractDecString: 两个数相减(防止精度丢失) multiplyDecString: 两个数相乘(防止精度丢失) divideDecString: 两个数相除(防止精度丢失)
- 其他待完善,补充圆角,圆形切割图片,以及处理本地等图片的方法。后期完善获取图片属性,图片压缩,各种切圆角方法。
base64ToImage: 将base64流转化为图片 fileToBase64: 将图片file转化为base64 networkImageToBase64: 将网络链接图片转化为base64 assetImageToBase64: 将asset图片转化为base64 showNetImageWh: 加载网络图片,并且指定宽高大小。使用默认预加载loading和错误视图 showNetImageWhError: 加载网络图片,并且指定宽高大小。传入错误视图 showNetImageWhPlaceError: 加载网络图片,并且指定宽高大小。传入预加载,错误视图 showNetImageWhClip: 加载网络图片,并且指定宽高大小,切割圆角 showNetImageCircle: 加载网络图片,切割圆形图片
- 处理url解析相关工具类
containsTarget: 判断url链接是否包含参数 getFirstPath: 获取url中第一个参数 getUrlHost: 获取url链接中host getUrlScheme: 获取url链接中scheme getFirstPath: 获取url中第一个参数 isURL: 返回输入是否匹配url的正则表达式
- 常用正则表达式,借鉴AndroidUtils工具类,将java转为dart
isMobileSimple: 简单验证手机号 isMobileExact: 精确验证手机号 isTel: 验证电话号码 isIDCard15: 验证身份证号码 15 位 isIDCard18: 简单验证身份证号码 18 位 isIDCard18Exact: 精确验证身份证号码 18 位 isEmail: 验证邮箱 isURL: 验证 URL isZh: 验证汉字 isUsername: 验证用户名 isDate: 验证 yyyy-MM-dd 格式的日期校验,已考虑平闰年 isIP: 验证 IP 地址 match: 判断是否匹配正则 RegexConstants.REGEX_DOUBLE_BYTE_CHAR: 双字节 RegexConstants.REGEX_BLANK_LINE: 空行 RegexConstants.REGEX_QQ_NUM: QQ 号 RegexConstants.REGEX_CHINA_POSTAL_CODE: 邮编 RegexConstants.REGEX_INTEGER: 整数 RegexConstants.REGEX_POSITIVE_INTEGER: 正整数 RegexConstants.REGEX_NEGATIVE_INTEGER: 负整数 RegexConstants.REGEX_NOT_NEGATIVE_INTEGER: 非负整数 RegexConstants.REGEX_NOT_POSITIVE_INTEGER: 非正整数 RegexConstants.REGEX_FLOAT: 浮点数 RegexConstants.REGEX_POSITIVE_FLOAT: 正浮点数 RegexConstants.REGEX_NEGATIVE_FLOAT: 负浮点数 RegexConstants.REGEX_NOT_NEGATIVE_FLOAT: 非负浮点数 RegexConstants.REGEX_NOT_POSITIVE_FLOAT: 非正浮点数
- Object相关工具类如下:
isNull: 判断对象是否为null isNullOrBlank: 检查数据是否为空或空(空或只包含空格) isEmptyString: 判断字符串是否为空 isEmptyList: 判断集合是否为空 isEmptyMap: 判断字典是否为空 isEmpty: 判断object对象是否为空 isNotEmpty: 判断object是否不为空 compareListIsEqual: 比较两个集合是否相同 getLength: 获取object的长度
- 验证相关工具类
isNumericOnly: 检查字符串是否只包含数字 isAlphabetOnly: 检查字符串是否只包含字母。(没有空格) isBool: 检查字符串是否为布尔值 isVector: 检查string是否为vector文件 isImage: 检查字符串是否为图像文件 isAudio: 检查字符串是否为音频文件 isVideo: 检查字符串是否为视频文件 isTxt: 检查字符串是否为txt文本文件 isDocument: 检查字符串是否为doc文件 isExcel: 检查字符串是否为excel文件 isPPT: 检查字符串是否为ppt文件 isAPK: 检查字符串是否为apk文件 isPDF: 检查字符串是否为pdf文件 ishtml: 检查字符串是否为html文件 isURL: 检查字符串是否为url文件 isEmail: 检查字符串是否为email文件 isDateTime: 检查字符串是否为时间 isMD5: 检查字符串是否为md5 isSHA1: 检查字符串是否为sha1 isSHA256: 检查字符串是否为sha256 isIPv4: 检查字符串是否为ipv4 isIPv6: 检查字符串是否为ipv6 isPalindrome: 检查字符串是否为回文 isCaseInsensitiveContains: 检查a是否包含b(将大小写字母视为相同或解释)。 isCaseInsensitiveContainsAny: 检查a中是否包含b或b中是否包含a(将大小写字母视为相同)。 isCamelCase: 检查字符串值是否驼峰大小写 isCapitalize: 检查字符串值是否大写
21.Text文本工具类
- 文本相关工具类如下:
isEmpty: 判断文本内容是否为空 isNotEmpty: 判断文本内容是否不为空 startsWith: 判断字符串是以xx开头 contains: 判断字符串中是否包含xx abbreviate: 使用点缩写字符串 compare: 比较两个字符串是否相同 hammingDistance: 比较两个长度一样的字符串有几个字符不同 formatDigitPattern: 每隔 x位 加 pattern。比如用来格式化银行卡 formatSpace4: 每隔4位加空格 hideNumber: 隐藏手机号中间n位,比如隐藏手机号 13667225184 为 136****5184 replace: 替换字符串中的数据 split: 按照规则切割字符串,返回数组 reverse: 反转字符串
- LocatizationExtensionState类中:String getString(String id)
- 获取不同Locales渠道语言内容。举例:使用:var name = context.getString("name");
- LocatizationExtensionContext类中:String getString(String id)
- 获取不同Locales渠道语言内容
- 如何添加不同渠道语言内容。写在 main 函数中 runApp 之前
AppLocalizations.supportedLocales = [ const Locale(\'en\', \'US\'), const Locale(\'pt\', \'BR\'), const Locale(\'ja\', \'JP\'), const Locale(\'zh\', \'CN\'), ];
24.SPI帮助工具类
- spi简单介绍
- Service Locator可以将接口(抽象基类)与具体实现分离和解耦合,同时允许通过接口从App中的任何位置访问具体实现。
//第一步注册 GetIt serviceLocator = GetIt.instance; getIt.registerSingleton< BusinessService> (new BusinessServiceImpl()); //第二步使用 BusinessService businessService = serviceLocator< BusinessService> (); businessService.noneBusinessPattern(); //第三步解绑 serviceLocator.resetLazySingleton< BusinessService> ();
- 计时器辅助工具类
TimerUtils: 创建倒计时器 setTotalTime: 设置倒计时总时间 setInterval: 设置Timer间隔 startTimer: 启动定时Timer updateTotalTime: 重设倒计时总时间 isActive: 判断Timer是否启动 pauseTimer: 暂停倒计时器 cancel: 取消计时器 setOnTimerTickCallback: 设置倒计时器的监听
26.1 int拓展类:ExtensionInt
- ExtensionInt拓展类
isPalindrome: 检查int是否为回文 isOneAKind: 检查所有数据是否具有相同的值 toBinary: 转换int值为二进制 toBinaryInt: 转换int值为二进制int fromBinary: 转换int值为二进制字符串
- ExtensionList拓展类
toJsonString: 将list转化为json字符串 getJsonPretty: 将list转化为json字符串,换行 valueTotal: 获取num列表的总值(int/double) isNull: 判断对象是否为null isNullOrBlank: 检查数据是否为空或空(空或只包含空格)
- ExtensionMap拓展类【set拓展类同理】
toJsonString: 将map转化为json字符串 getJsonPretty: 将map转化为json字符串换行 isNull: 判断对象是否为null isNullOrBlank: 检查数据是否为空或空(空或只包含空格)
- ExtensionString拓展类
isNull: 判断对象是否为null isNullOrBlank: 检查数据是否为空或空(空或只包含空格) isNumericOnly: 检查字符串是否只包含数字 isAlphabetOnly: 检查字符串是否只包含字母。(没有空格) isBool: 检查字符串是否为布尔值 isVector: 检查string是否为vector文件 isImage: 检查字符串是否为图像文件 isAudio: 检查字符串是否为音频文件 isVideo: 检查字符串是否为视频文件 isTxt: 检查字符串是否为txt文本文件 isDocument: 检查字符串是否为doc文件 isExcel: 检查字符串是否为excel文件 isPPT: 检查字符串是否为ppt文件 isAPK: 检查字符串是否为apk文件 isPDF: 检查字符串是否为pdf文件 isHTML: 检查字符串是否为html文件 isURL: 检查字符串是否为url文件 isEmail: 检查字符串是否为email文件 isDateTime: 检查字符串是否为时间 isMD5: 检查字符串是否为md5 isSHA1: 检查字符串是否为sha1 isSHA256: 检查字符串是否为sha256 isIPv4: 检查字符串是否为ipv4 isIPv6: 检查字符串是否为ipv6 isPalindrome: 检查字符串是否为回文 isCaseInsensitiveContains: 检查a是否包含b(将大小写字母视为相同或解释)。 isCaseInsensitiveContainsAny: 检查a中是否包含b或b中是否包含a(将大小写字母视为相同)。 isCamelCase: 检查字符串值是否驼峰大小写 isCapitalize: 检查字符串值是否大写
- 转化相关的操作工具类
toBinary: 转换int值为二进制,比如:15 => 1111 toBinaryInt: 转换int值为二进制 fromBinary: 转换二进制为int值 capitalize: 字符串内的每个单词都要大写 capitalizeFirst: 字符串的首字母大写,其他字母小写 removeAllWhitespace: 删除字符串内的所有空格 numericOnly: 提取字符串的数值
- 针对flutter全局异常捕获,可以使用:handle_exception
//如果使用,在main方法中,如下所示: hookCrash(() { runApp(MainApp()); });
- 捕获一场打印输出:
I/flutter ( 9506): yc e— — — — — — — — — — st — — — — — — — — — — — — — I/flutter ( 9506): yc e | handle_exception :e----> MissingPluginException(No implementation found for method getAll on channel plugins.flutter.io/shared_ I/flutter ( 9506): yc e | preferences) I/flutter ( 9506): yc e— — — — — — — — — — ed — — — — — — — — — ---— — I/flutter ( 9506): yc ehandle_exception :stack---->
- 解析xml/html数据工具类
- ByteUtils转化相关的操作工具类
toBinary: 转换int值为二进制 toReadable: 将字节数组转换为可读字符串 toBase64: 将字节数组转换为base64字符串 fromBase64: 转换base64字符串到字节数组 clone: 克隆字节数组 same: 判断两个字节是否相同 extract: 从字节序列中提取数据 combine: 将两个字节拼接 insert: 在字节某个索引处插入字节 remove: 在字节某个索引处移除字节
40.2 随机工具类
- RandomUtils
randomColor: 生成一个表示十六进制颜色的随机整数 randomString: 生成指定长度或随机长度的随机字符串 randInt: 在开始和结束之间生成一个随机数 randomElement: 从列表中返回一个随机元素
- PlatformUtils。该工具类可以通过获取平台,然后设置一个value区别平台信息。
final value = https://www.songbingjia.com/android/PlatformUtils.select( ios:"ios", android: "android", web: "web", fuchsia: "fuchsia", macOS: () => "macOS", windows: () => "windows", linux: () => "linux", ); //结果,在Android设备上,value就是:android
- 系统工具类,主要是软键盘操作和复制内容到剪切板
copyToClipboard: 拷贝文本内容到剪切板 hideKeyboard: 隐藏软键盘,具体可看:TextInputChannel showKeyboard: 展示软键盘 clearClientKeyboard: 清除数据
- https://github.com/Blankj/AndroidUtilCode
- https://pub.dev/packages/emote_utils/versions
- https://blog.csdn.net/iotjin/article/details/104881659
- https://cloud.tencent.com/developer/article/1772198
- https://blog.csdn.net/yechaoa/article/details/89845701
- https://blog.csdn.net/aau88497/article/details/102344984
- https://github.com/Sky24n/flustars
- https://github.com/a14n/dart-decimal
- https://pub.dev/packages?q=html_xml_parser
推荐阅读
- 由美团文章“一款可以让大型iOS工程编译速度提升50%的工具”引出的.hmap文件探索(上)
- Android技术分享| 自定义ViewGroup实现直播间大小屏无缝切换
- 如何正确跟踪广告转化数据,优化广告投放效果()
- iOS开发面试只需知道这些,技术基本通关!(数据结构与算法篇附加安全加密)
- 由美团文章“一款可以让大型iOS工程编译速度提升50%的工具”引出的.hmap文件(下)hmap落地
- 八天让iOS开发者上手Flutter!
- 这么递名片才高效!教你给应用开发个交换名片功能
- Flutter如何状态管理
- iOS开发面试只需知道这些,技术基本通关!(多线程篇)