Skip to content
导航栏

字符串

camelize

将 xx-xx 转为 xxXx 大驼峰格式

typescript
import { camelize } from '@fang-kang/js-utils';

camelize('get-data'); // getData

ensurePrefix

确保前缀有这个字符串

typescript
import { ensurePrefix } from '@fang-kang/js-utils';

ensurePrefix('a', 'b'); // ab

ensureSuffix

确保后缀有这个字符串

typescript
import { ensureSuffix } from '@fang-kang/js-utils';

ensureSuffix('a', 'b'); // ba

hyphenate

将大驼峰转为 xx-xx

typescript
import { hyphenate } from '@fang-kang/js-utils';

hyphenate('getData'); // get-datas

pwdLevel

检测字符串强度

typescript
import { pwdLevel } from '@fang-kang/js-utils';

pwdLevel('1'); // 0

spaceFormat

将多个空格统一处理为空

typescript
import { spaceFormat } from '@fang-kang/js-utils';

spaceFormat('string');

trim

删除空格

typescript
import { trim } from '@fang-kang/js-utils';

/**
 * 删除空格
 * @param { string } s 字符串
 * @param { TrimType } type 所有 | 前置 | 前后 | 后置 'all' | 'pre' | 'around' | 'post'
 * @defalut around
 * @returns
 */

checkStr

判断类型集合

typescript
import { checkStr } from '@fang-kang/js-utils';

checkStr();

/**
 *  case 'phone': //手机号码
      return /^1[3|4|5|6|7|8|9][0-9]{9}$/.test(str);
    case 'tel': //座机
      return /^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/.test(str);
    case 'card': //身份证
      return /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(str);
    case 'pwd': //密码以字母开头,长度在6~18之间,只能包含字母、数字和下划线
      return /^[a-zA-Z]\w{5,17}$/.test(str);
    case 'postal': //邮政编码
      return /[1-9]\d{5}(?!\d)/.test(str);
    case 'QQ': //QQ号
      return /^[1-9][0-9]{4,9}$/.test(str);
    case 'email': //邮箱
      return /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/.test(str);
    case 'money': //金额(小数点2位)
      return /^\d*(?:\.\d{0,2})?$/.test(str);
    case 'URL': //网址
      return /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/.test(str);
    case 'IP': //IP
      return /((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/.test(str);
    case 'date': //日期时间
      return (
        /^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) ||
        /^(\d{4})\-(\d{2})\-(\d{2})$/.test(str)
      );
    case 'number': //数字
      return /^[0-9]$/.test(str);
    case 'english': //英文
      return /^[a-zA-Z]+$/.test(str);
    case 'chinese': //中文
      return /^[\\u4E00-\\u9FA5]+$/.test(str);
    case 'lower': //小写
      return /^[a-z]+$/.test(str);
    case 'upper': //大写
      return /^[A-Z]+$/.test(str);
    case 'HTML': //HTML标记
      return /<("[^"]*"|'[^']*'|[^'">])*>/.test(str);
    default:
      return true;
 */

luhnCheck

Luhn 算法的实现,用于验证各种标识号,例如信用卡号,IMEI 号,国家提供商标识号等。

与 String.prototype.split('')结合使用,以获取数字数组。获得最后一个数字。实施 luhn 算法。如果被整除,则返回,否则返回。

typescript
import { luhnCheck } from '@fang-kang/js-utils';

luhnCheck('4485275742308327'); // true
luhnCheck('6011329933655299'); //  false
luhnCheck('123456789'); // false

Released under the MIT License.