@qubit-ltd/common-util
v5.4.7
Published
A JavaScript ES6 library of common utility functions
Readme
@qubit-ltd/common-util
@qubit-ltd/common-util 是一个 JavaScript ES6 通用工具函数库,可简化日常开发任务。这个库提供了一系列全面的辅助函数,用于字符串操作、对象属性访问、数据类型检查、浏览器检测、DOM 操作等多种功能。
目录
安装
您可以通过 npm 或 yarn 安装 @qubit-ltd/common-util:
# 使用 npm
npm install @qubit-ltd/common-util
# 使用 yarn
yarn add @qubit-ltd/common-util使用
// 导入特定函数
import { isEmpty, formatLocalDate, jsonStringify } from '@qubit-ltd/common-util';
// 检查值是否为空
const empty = isEmpty(''); // true
// 格式化日期
const date = new Date();
const formattedDate = formatLocalDate(date); // 例如: '2023-05-21'
// 将带有循环引用的 JSON 对象转为字符串
const obj = { a: 1 };
obj.self = obj; // 循环引用
const json = jsonStringify(obj); // 处理循环引用功能特性
字符串操作
trimString: 去除字符串中的空白uppercaseString: 将字符串转换为大写trimUppercaseString: 去除空白并转为大写dequote: 移除字符串中的引号toString: 将值转换为字符串表示形式,可自动处理对象的循环引用format: 简单的字符串格式化工具splitOnFirst: 在指定分隔符第一次出现的位置将字符串分割成两部分
对象和属性处理
getProperty: 使用点号表示法安全地获取对象属性setProperty: 使用点号表示法设置对象属性hasProperty: 使用点号表示法检查对象是否有特定属性decycle: 移除对象中的循环引用includeKeys: 使用谓词函数或键数组/集合过滤对象键值,返回包含指定键的新对象excludeKeys: 使用谓词函数或键数组/集合过滤对象键值,返回排除指定键的新对象ArrayUtils: 数组工具函数集合,包括remove和removeIf等功能
类型检查
isEmpty: 检查值是否为空isUndefinedOrNull: 检查值是否为 undefined 或 nullisUndefinedOrNullOrEmptyString: 检查值是否为 undefined、null 或空字符串isUndefinedOrNullOrEmptyArray: 检查值是否为 undefined、null 或空数组checkArgumentType: 验证函数参数的类型
浏览器和环境检测
isChrome,isFirefox,isEdge,isIE,isSafari,isOpera: 浏览器检测函数isIos,isAndroid: 移动操作系统检测isWechat: 检测是否在微信环境中运行isMyNanjingApp: 检测是否在我的南京 App 中运行
DOM 操作
addClassToHmlElement: 为 HTML 元素添加 CSS 类removeClassFromHmlElement: 从 HTML 元素中移除 CSS 类isHtmlElement: 检查值是否为 HTML 元素isHtmlElementHasClass: 检查 HTML 元素是否有特定类fixScroll: 修复移动设备上的滚动问题scrollTo: 平滑滚动到元素或位置getAncestorClasses: 获取元素及其祖先元素的 CSS 类数组
日期和时间格式化
createDate: 从各种输入格式创建日期formatLocalDate: 以本地日期格式格式化日期formatLocalTime: 以本地时间格式格式化时间formatLocalDatetime: 以本地格式格式化日期和时间
URL 和查询字符串处理
getSearch: 获取 URL 的搜索部分getParsedSearch: 解析 URL 的搜索部分getSearchParam: 从 URL 获取特定的搜索参数addSearchParams: 向 URL 添加搜索参数removeSearchParam: 从 URL 移除搜索参数normalizeUrl: 规范化 URLuriEncode,uriDecode: 编码/解码 URI 组件extractOssUrlInfo: 从 OSS URL 提取信息
其他实用工具
sleep: 创建在指定时间后解析的 PromiseloadScript: 动态加载脚本rafThrottle: 使用 requestAnimationFrame 节流函数stringToFloat: 将字符串转换为浮点数round: 将数字舍入到指定精度splitDigits: 将数字拆分为各个数字stringToMoney: 将字符串格式化为货币形式emptyToNull: 将空值转换为 nullrestoreVueManaged: 将 Vue 托管的对象转换回原生对象
贡献
如果您发现任何问题或有改进建议,请随时在 GitHub 仓库 中提出问题或提交拉取请求。
许可证
@qubit-ltd/common-util 在 Apache 2.0 许可下分发。 有关更多详细信息,请参阅 LICENSE 文件。
