打造开箱即用的js工具库之xijs更新指南(v1.2.2)

news/2024/11/29 10:43:33/

fe420879fc0b90086a869291fe41cbd2.png

xijs 是一款开箱即用的 js 业务工具库, 聚集于解决业务中遇到的常用的js函数问题, 帮助开发者更高效的进行业务开发.

接下来就和大家一起分享一下v1.2.2 版本的更新内容.

github: https://github.com/MrXujiang/xijs

1. 添加常用判断函数

该模块主要由知乎作者 萌萌你萌不萌啊 贡献, 添加内容如下:

  • isPhone - 判断手机号格式

  • isEmail - 判断邮箱函数

  • isIdCard - 判断身份证格式函数

  • isPhone - 判断手机号格式

  • lang - 判断中英文

使用方式如下:

import { isPhone,isEmail,lang
} from 'xijs';// 判断是否为正确的邮箱格式
console.log(isEmail('1111@qq.com')); // -> true// 判断是否为正确的手机格式
console.log(isPhone(13334433333)); // -> true// 判断是否为英文
console.log(lang.isEn('sadsad')); // -> true
// 判断是否为中文
console.log(lang.isCn('萨达')); // -> true

2. 添加常用数学计算函数

该模块主要由 EasyRo 贡献, 添加内容如下:

  • factorial - 阶乘计算

  • fibonacci - 计算斐波那契数

  • sum - 求和数组

这几个方法对于一些需要用到数学计算的场景非常有帮助. 接下来介绍一下具体用法:

4489e8b8bd9b6f5e68b5752c1aa79015.pngbd92da88683fab81118f90d0d1c11620.png869c12ceec6695d62e06b207adbd04fd.png

接下来我们跑一下单元测试, 对整个库做一个全面的扫描:

e18f019ac7af67a100f80eee41a0ebaf.png

整个测试一共花了17.68s, 测试全部通过, 各位小伙伴们可以放松食用.

为了方便大家更好的了解 xijs 这个库, 我列一个完整的目录结构供大家参考, 也可以直接用 xijs 的在线文档中去参考学习.

  • 浏览器相关

    • getRuntimeEnv - 获取运行环境

    • getSelection - 获取选中文本

    • redirect - 重定向

    • store - 本地存储库

  • 字符串操作

    • base64 - base64编码和解码

    • camelize - 横线转驼峰命名

    • charCount - 获取字符数

    • formatNumber - 数值千分位格式化

    • formatPercent - 值转换为百分数表示

    • hyCompact - 紧凑型驼峰命名转换

    • hyphenate - 驼峰命名转横线命名

    • randomStr - 生成随机字符串

    • repeat - 生成重复字符串

    • uuid - 生成唯一id

  • 常用判断函数

    • isArray - 判断数组类型

    • isEmpty - 判断空对象

    • isPc - 判断设备类型

    • isPhone - 判断手机号格式

    • isEmail - 判断邮箱函数

    • isIdCard - 判断身份证格式函数

    • isPhone - 判断手机号格式

    • lang - 判断中英文

  • 数据结构相关

    • cloneDeep - 数据深拷贝

    • formatDate - 时间格式化

    • getRawType - 获取数据类型

    • obj2url - 将对象参数解析为url字符串

    • transformTree - 扁平转树结构

    • url2obj - url字符串转对象

  • 图片处理函数

    • compressImg - 自定义压缩图片函数

    • file2img - 文件转图片对象

    • hex2rgba - hex色值转rgba

    • rgba2obj - 将rgba值转化为rgba对象

  • js高级函数

    • debounce - 防抖函数

    • parser - json超级解析器

    • sleep - 睡眠函数

    • throttle - 节流函数

  • 常用算法和数据结构

    • bubbleSort - 冒泡排序

    • quickSort - 快速排序

  • 数学计算

    • average - 计算数组平均值

    • difference - 创建一个排除指定项的数组

    • random - 返回区域内随机数

    • shuffle - 打乱数组

    • factorial - 阶乘计算

    • fibonacci - 计算斐波那契数

    • sum - 求和数组

  • 几何计算

    • coordinatesInCircle - 生成圆内任意坐标

    • coordinatesInRect - 生成矩形内任意坐标

    • judgePointInCircle - 判断一点是否在圆内

欢迎大家star推荐, 让前端工作更高效. 如果你也想参与该项目的共建, 随时和我联系.

github: https://github.com/MrXujiang/xijs

以上便是本次分享的内容,希望对你有所帮助^_^

喜欢的话别忘了 分享、点赞、收藏 三连哦~。

c9b0bb036c15e479604c206c0b74caf3.gif

从零搭建全栈可视化大屏制作平台V6.Dooring

从零设计可视化大屏搭建引擎

Dooring可视化搭建平台数据源设计剖析

可视化搭建的一些思考和实践

基于Koa + React + TS从零开发全栈文档编辑器(进阶实战

点个在看你最好看


http://www.ppmy.cn/news/39681.html

相关文章

朴素贝叶斯算法

# -*-coding:utf-8-*- """ Author: sunchang Desc: 代码4-7 朴素贝叶斯实现对异常账户检测 """ import numpy as np class NaiveBayesian: def __init__(self, alpha): self.classP dict() self.classP_f…

蓝桥杯真题05

重新排序 问题描述 给定一个数组 A 和一些查询 Li,Ri 求数组中第 Li 至第 Ri个元素之和。 小蓝觉得这个问题很无聊, 于是他想重新排列一下数组, 使得最终每个查询结果的和尽可能地大。小蓝想知道相比原数组, 所有查询结果的总和最多可以增加多少? 输入格式 输入第一行包含…

什么性格的人适合报考地质学类专业?(高考志愿填报选专业)

地质学 是一门涉及自然科学、人文科学等多个领域的综合性学科,它需要学生具备一定的理论素养和实践能力。在选择地质学类专业时,应该考虑自己的性格特点,以便更好地适应这门学科。 也有很多同学表示,我不清楚自己的性格有什么特征…

HTML5 内联 SVG

文章目录HTML5 内联 SVG什么是SVG?SVG优势浏览器支持把 SVG 直接嵌入 HTML 页面SVG 与 Canvas两者间的区别Canvas 与 SVG 的比较HTML5 内联 SVG HTML5 支持内联 SVG。 什么是SVG? SVG 指可伸缩矢量图形 (Scalable Vector Graphics)SVG 用于定义用于网…

c#编码问题

产生乱码的原因(只有文本文件才会乱码):文本文件存储时采用的编码,与读取时采用的编码不一致,就会造成乱码问题。解决:采用统一的编码就ok. 文本文件编码,文本文件有不同的存储方式,…

第一次在大厂工作的感想——滴滴

文章目录前言相处氛围工作时间培养方案学习方面未来展望前言 很久没更新了呀,因为最近比较忙。二月底刚结束第一段实习,紧接着就拿到了滴滴offer,在学校呆了半个月就开启了第二段实习之旅。从浙江到河南再到北京,仅隔半个月。这次…

【python设计模式】6、装饰器模式

哲学思想 装饰器模式是一种结构型设计模式,其哲学思想是通过组合和装饰对象来扩展其功能,而不需要修改其底层代码或继承新的类。它遵循了"开放封闭原则",即对扩展开放,对修改关闭。 该模式的核心概念是将一个类包装在…

【李宏毅】深度学习——HW4-Speaker Identification

Speaker Identification 1.Goal 根据给定的语音内容,识别出说话者是谁 2.Data formats 2.1data directory 目录下有三个json文件和很多pt文件,三个json文件作用标注在下图中,pt文件就是语音内容。 mapping文件 metadata文件 n_mels:Th…