你是怎么宰割银行卡号的,通用办法?
阐明,一下代码均通过 ts 编写,请再运行时先搭建好 ts 运行时环境。
办法一
// 正则宰割任意字符串
interface IStrType {length?: number}
// 束缚泛型
export interface IFunc<T extends IStrType = string, U = number, Z = string>{( value:T | number, limits: U, suffix: Z): string
}
const regExpFormatStr: IFunc
= (value, limits, suffix) => {const _regExp: RegExp = new RegExp(`.(?=(.{${limits}})+$)`, 'g');
return (typeof value !== "number" && value?.length ? value : value.toString()).replace(_regExp, $n1 => {return `${$n1}${suffix}`
});
}
办法二 (有点 cuo)
/*
* @desc 解决数字,并且增加宰割
*/
interface IToolFunction<T, U> {(target: T, limits?: number): U
}
type ITF<T, U> = IToolFunction<T, U>;
const numHandler: ITF<any, string> = (target: any, limits: number = 4) => {
// 初始化数组
let _$: string[] = target.toString().split('');
// 记录原始数组长
let _len: number = _$.length;
// 新格局长期数组
let _format: string[] = [];
// loop
for(let i: number = 0; i < _len; i++) {
// 轮询数组长
let _loopLen: number = _$.length;
if(_loopLen % limits === 0) {_format.push(_$.splice(0, limits).join('')); }
_format.push(_$.splice(0, _loopLen % limits).join(''));
}
return _format.join(' ');
}
小结
第一种办法提供了宰割字符串的串、宰割单位、宰割符。第二种办法默认空格,如果你有好的办法,欢送提供,如果须要转载,请注明出处。