字符串工具类详解编程语言

/** 
* @author: 苗士军 
* @description 字符串工具类 
*/ 
StringUtils = { 
/** 
* @description 判断字符串是否为空 
* @param input 
* @return {boolean} 
*/ 
isEmpty: function(input) { 
return input == null || input == ''; 
}, 
/** 
* @description 判断字符串是否不为空 
* @param input 
* @return {boolean} 
*/ 
isNotEmpty: function(input) { 
return !this.isEmpty(input); 
}, 
/** 
* @description 判断字符串是否全是空格 
* @param input 
* @return {boolean} 
*/ 
isBlank: function(input) { 
return input == null || /^/s*$/.test(input); 
}, 
/** 
* @description 判断字符串是否不全是空格 
* @param input 
* @return {boolean} 
*/ 
isNotBlank: function(input) { 
return !this.isBlank(input); 
}, 
/** 
* @description 去除字符串首尾空格 
* @param input 
* @return {void|string|XML} 
*/ 
trim: function(input) { 
return input.replace(/^/s+|/s+$/g, ''); 
}, 
/** 
* @description 输入去掉首尾空格 
* @param input 
* @return {*} 
*/ 
trimToEmpty: function(input) { 
return input == null ? "" : this.trim(input); 
}, 
/** 
* @description 字符串是否以字符串开头 
* @param input 
* @param prefix 
* @return {boolean} 
*/ 
startsWith: function(input, prefix) { 
return input.indexOf(prefix) === 0; 
}, 
/** 
* @description 字符串是否以字符串结尾 
* @param input 
* @param prefix 
* @return {boolean} 
*/ 
endsWith: function(input, suffix) { 
return input.lastIndexOf(suffix) === 0; 
}, 
/** 
* @description 字符串是否包含某些字符串 
* @param input 
* @param searchSeq 
* @return {boolean} 
*/ 
contains: function(input, searchSeq) { 
return input.indexOf(searchSeq) >= 0; 
}, 
/** 
* @description 判断字符串是否相等 
* @param input1 
* @param input2 
* @return {boolean} 
*/ 
equals: function(input1, input2) { 
return input1 == input2; 
}, 
/** 
* @description 字符串忽略大小写比较是否相等 
* @param input1 
* @param input2 
* @return {boolean} 
*/ 
equalsIgnoreCase: function(input1, input2) { 
return input1.toLocaleLowerCase() == input2.toLocaleLowerCase(); 
}, 
/** 
* @description 判断字符串是否包含空格 
* @param input 
* @return {*|boolean} 
*/ 
containsWhitespace: function(input) { 
return this.contains(input, ' '); 
}, 
/** 
* @description 生成指定个数的字符 
* @param ch 
* @param repeatTimes 
* @return {string} 
*/ 
repeat: function(ch, repeatTimes) { 
var result = ""; 
for(var i = 0; i < repeatTimes; i++) { 
result += ch; 
} 
return result; 
}, 
/** 
* @description 去除全部空格 
* @param input 
* @return {void|string|XML} 
*/ 
deleteWhitespace: function(input) { 
return input.replace(//s+/g, ''); 
}, 
/** 
* @description 字符串右边添加重复几次的固定字符串 
* @param input 
* @param size 
* @param padStr 
* @return {*} 
*/ 
rightPad: function(input, size, padStr) { 
return input + this.repeat(padStr, size); 
}, 
/** 
* @description 字符串左边添加重复几次的固定字符串 
* @param input 
* @param size 
* @param padStr 
* @return {*} 
*/ 
leftPad: function(input, size, padStr) { 
return this.repeat(padStr, size) + input; 
}, 
/** 
* @description  首小写字母转大写 
* @param input 
* @return {*} 
*/ 
capitalize: function(input) { 
var strLen = 0; 
if(input == null || (strLen = input.length) == 0) { 
return input; 
} 
return input.replace(/^[a-z]/, function(matchStr) { 
return matchStr.toLocaleUpperCase(); 
}); 
}, 
/** 
* @description 首大写字母转小写 
* @param input 
* @return {*} 
*/ 
uncapitalize: function(input) { 
var strLen = 0; 
if(input == null || (strLen = input.length) == 0) { 
return input; 
} 
return input.replace(/^[A-Z]/, function(matchStr) { 
return matchStr.toLocaleLowerCase(); 
}); 
}, 
/** 
* @description 大写转小写,小写转大写 
* @param input 
* @return {void|string|XML} 
*/ 
swapCase: function(input) { 
return input.replace(/[a-z]/ig, function(matchStr) { 
if(matchStr >= 'A' && matchStr <= 'Z') { 
return matchStr.toLocaleLowerCase(); 
} else if(matchStr >= 'a' && matchStr <= 'z') { 
return matchStr.toLocaleUpperCase(); 
} 
}); 
}, 
/** 
* @description 统计含有的子字符串的个数 
* @param input 
* @param sub 
* @return {number} 
*/ 
countMatches: function(input, sub) { 
if(this.isEmpty(input) || this.isEmpty(sub)) { 
return 0; 
} 
var count = 0; 
var index = 0; 
while((index = input.indexOf(sub, index)) != -1) { 
index += sub.length; 
count++; 
} 
return count; 
}, 
/** 
* @description 只包含字母 
* @param input 
* @return {boolean} 
*/ 
isAlpha: function(input) { 
return /^[a-z]+$/i.test(input); 
}, 
/** 
* @description 只包含字母、空格 
* @param input 
* @return {boolean} 
*/ 
isAlphaSpace: function(input) { 
return /^[a-z/s]*$/i.test(input); 
}, 
/** 
* @description 只包含字母、数字 
* @param input 
* @return {boolean} 
*/ 
isAlphanumeric: function(input) { 
return /^[a-z0-9]+$/i.test(input); 
}, 
/** 
* @description 只包含字母、数字和空格 
* @param input 
* @return {boolean} 
*/ 
isAlphanumericSpace: function(input) { 
return /^[a-z0-9/s]*$/i.test(input); 
}, 
/** 
* @description 数字 
* @param input 
* @return {boolean} 
*/ 
isNumeric: function(input) { 
return /^(?:[1-9]/d*|0)(?:/./d+)?$/.test(input); 
}, 
/** 
* @description 小数 
* @param input 
* @return {boolean} 
*/ 
isDecimal: function(input) { 
return /^[-+]?(?:0|[1-9]/d*)/./d+$/.test(input); 
}, 
/** 
* @description 小数(只能出现-) 
* @param input 
* @return {boolean} 
*/ 
isNegativeDecimal: function(input) { 
return /^/-?(?:0|[1-9]/d*)/./d+$/.test(input); 
}, 
/** 
* @description 小数(只能出现+) 
* @param input 
* @return {boolean} 
*/ 
isPositiveDecimal: function(input) { 
return /^/+?(?:0|[1-9]/d*)/./d+$/.test(input); 
}, 
/** 
* @description 整数 
* @param input 
* @return {boolean} 
*/ 
isInteger: function(input) { 
return /^[-+]?(?:0|[1-9]/d*)$/.test(input); 
}, 
/** 
* @description 整数(+) 
* @param input 
* @return {boolean} 
*/ 
isPositiveInteger: function(input) { 
return /^/+?(?:0|[1-9]/d*)$/.test(input); 
}, 
/** 
* @description 整数(-) 
* @param input 
* @return {boolean} 
*/ 
isNegativeInteger: function(input) { 
return /^/-?(?:0|[1-9]/d*)$/.test(input); 
}, 
/** 
* @description 只包含数字和空格 
* @param input 
* @return {boolean} 
*/ 
isNumericSpace: function(input) { 
return /^[/d/s]*$/.test(input); 
}, 
/** 
* @description 碰到字符串是否是空格 
* @param input 
* @return {boolean} 
*/ 
isWhitespace: function(input) { 
return /^/s*$/.test(input); 
}, 
/** 
* @description 判断字符串是否全是小写 
* @param input 
* @return {boolean} 
*/ 
isAllLowerCase: function(input) { 
return /^[a-z]+$/.test(input); 
}, 
/** 
* @description 判断字符串是否全是大写 
* @param input 
* @return {boolean} 
*/ 
isAllUpperCase: function(input) { 
return /^[A-Z]+$/.test(input); 
}, 
/** 
* @description 字符串初始化 
* @param input 
* @param defaultStr 
* @return {*} 
*/ 
defaultString: function(input, defaultStr) { 
return input == null ? defaultStr : input; 
}, 
/** 
* @description 字符串初始化 
* @param input 
* @param defaultStr 
* @return {*} 
*/ 
defaultIfBlank: function(input, defaultStr) { 
return this.isBlank(input) ? defaultStr : input; 
}, 
/** 
* @description 字符串初始化 
* @param input 
* @param defaultStr 
* @return {*} 
*/ 
defaultIfEmpty: function(input, defaultStr) { 
return this.isEmpty(input) ? defaultStr : input; 
}, 
/** 
* @description 字符串反转 
* @param input 
* @return {string} 
*/ 
reverse: function(input) { 
if(this.isBlank(input)) { 
input; 
} 
return input.split("").reverse().join(""); 
}, 
/** 
* @description 删掉特殊字符(英文状态下) 
* @param input 
* @return {string|XML|void} 
*/ 
removeSpecialCharacter: function(input) { 
return input.replace(/[!-/:-@/[-`{-~]/g, ""); 
    }, 
/** 
* @description 只包含特殊字符、数字和字母(不包括空格,若想包括空格,改为[ -~]) 
* @param input 
* @return {boolean} 
*/ 
isSpecialCharacterAlphanumeric: function(input) { 
return /^[!-~]+$/.test(input); 
}, 
/** 
* @description 校验时排除某些字符串,即不能包含某些字符串 
* @param input 
* @param conditions {Object} conditions:里面有多个属性,如下: 
*  @param {String} matcherFlag 匹配标识 
* 0:数字;1:字母;2:小写字母;3:大写字母;4:特殊字符,指英文状态下的标点符号及括号等;5:中文; 
* 6:数字和字母;7:数字和小写字母;8:数字和大写字母;9:数字、字母和特殊字符;10:数字和中文; 
* 11:小写字母和特殊字符;12:大写字母和特殊字符;13:字母和特殊字符;14:小写字母和中文;15:大写字母和中文; 
* 16:字母和中文;17:特殊字符、和中文;18:特殊字符、字母和中文;19:特殊字符、小写字母和中文;20:特殊字符、大写字母和中文; 
* 100:所有字符; 
* @param {Array} excludeStrArr 排除的字符串,数组格式 
* @param {String} length 长度,可为空。1,2表示长度1到2之间;10,表示10个以上字符;5表示长度为5 
* @param {Boolean} ignoreCase 是否忽略大小写 
* conditions={matcherFlag:"0",excludeStrArr:[],length:"",ignoreCase:true} 
* @return {boolean} 
*/ 
isPatternMustExcludeSomeStr: function(input, conditions) { 
//参数 
var matcherFlag = conditions.matcherFlag; 
var excludeStrArr = conditions.excludeStrArr; 
var length = conditions.length; 
var ignoreCase = conditions.ignoreCase; 
//拼正则 
var size = excludeStrArr.length; 
var regex = (size == 0) ? "^" : "^(?!.*(?:{0}))"; 
var subPattern = ""; 
for(var i = 0; i < size; i++) { 
excludeStrArr[i] = StringUtils.escapeMetacharacterOfStr(excludeStrArr[i]); 
subPattern += excludeStrArr[i]; 
if(i != size - 1) { 
subPattern += "|"; 
} 
} 
regex = this.format(regex, [subPattern]); 
switch(matcherFlag) { 
case '0': 
regex += "//d"; 
break; 
case '1': 
regex += "[a-zA-Z]"; 
break; 
case '2': 
regex += "[a-z]"; 
break; 
case '3': 
regex += "[A-Z]"; 
break; 
case '4': 
regex += "[!-/:-@/[-`{-~]"; 
break; 
case '5': 
regex += "[/u4E00-/u9FA5]"; 
break; 
case '6': 
regex += "[a-zA-Z0-9]"; 
break; 
case '7': 
regex += "[a-z0-9]"; 
break; 
case '8': 
regex += "[A-Z0-9]"; 
break; 
case '9': 
regex += "[!-~]"; 
break; 
case '10': 
regex += "[0-9/u4E00-/u9FA5]"; 
break; 
case '11': 
regex += "[a-z!-/:-@/[-`{-~]"; 
break; 
case '12': 
regex += "[A-Z!-/:-@/[-`{-~]"; 
break; 
case '13': 
regex += "[a-zA-Z!-/:-@/[-`{-~]"; 
break; 
case '14': 
regex += "[a-z/u4E00-/u9FA5]"; 
break; 
case '15': 
regex += "[A-Z/u4E00-/u9FA5]"; 
break; 
case '16': 
regex += "[a-zA-Z/u4E00-/u9FA5]"; 
break; 
case '17': 
regex += "[/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '18': 
regex += "[/u4E00-/u9FA5!-~]"; 
break; 
case '19': 
regex += "[a-z/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '20': 
regex += "[A-Z/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '100': 
regex += "[/s/S]"; 
break; 
default: 
alert(matcherFlag + ":This type is not supported!"); 
} 
regex += this.isNotBlank(length) ? "{" + length + "}" : "+"; 
regex += "$"; 
var pattern = new RegExp(regex, ignoreCase ? "i" : ""); 
return pattern.test(input); 
}, 
/** 
* @description 消息格式化 
* @param {String} message 
* @param {Array} arr 
*/ 
format: function(message, arr) { 
return message.replace(/{(/d+)}/g, function(matchStr, group1) { 
return arr[group1]; 
}); 
}, 
/** 
* @description 把连续出现多次的字母字符串进行压缩。如输入:aaabbbbcccccd 输出:3a4b5cd 
* @param {String} input 
* @param {Boolean} ignoreCase : true or false 
*/ 
compressRepeatedStr: function(input, ignoreCase) { 
var pattern = new RegExp("([a-z])//1+", ignoreCase ? "ig" : "g"); 
return result = input.replace(pattern, function(matchStr, group1) { 
return matchStr.length + group1; 
}); 
}, 
/** 
* @description 校验必须同时包含某些字符串 
* @param {String} input 
* @param {Object} conditions:里面有多个属性,如下: 
* @param {String} matcherFlag 匹配标识 
* 0:数字;1:字母;2:小写字母;3:大写字母;4:特殊字符,指英文状态下的标点符号及括号等;5:中文; 
* 6:数字和字母;7:数字和小写字母;8:数字和大写字母;9:数字、字母和特殊字符;10:数字和中文; 
* 11:小写字母和特殊字符;12:大写字母和特殊字符;13:字母和特殊字符;14:小写字母和中文;15:大写字母和中文; 
* 16:字母和中文;17:特殊字符、和中文;18:特殊字符、字母和中文;19:特殊字符、小写字母和中文;20:特殊字符、大写字母和中文; 
* 100:所有字符; 
* @param {Array} excludeStrArr 排除的字符串,数组格式 
* @param {String} length 长度,可为空。1,2表示长度1到2之间;10,表示10个以上字符;5表示长度为5 
* @param {Boolean} ignoreCase 是否忽略大小写 
* conditions={matcherFlag:"0",containStrArr:[],length:"",ignoreCase:true} 
* @return {boolean} 
*/ 
isPatternMustContainSomeStr: function(input, conditions) { 
//参数 
var matcherFlag = conditions.matcherFlag; 
var containStrArr = conditions.containStrArr; 
var length = conditions.length; 
var ignoreCase = conditions.ignoreCase; 
//创建正则 
var size = containStrArr.length; 
var regex = "^"; 
var subPattern = ""; 
for(var i = 0; i < size; i++) { 
containStrArr[i] = Bee.StringUtils.escapeMetacharacterOfStr(containStrArr[i]); 
subPattern += "(?=.*" + containStrArr[i] + ")"; 
} 
regex += subPattern; 
switch(matcherFlag) { 
case '0': 
regex += "//d"; 
break; 
case '1': 
regex += "[a-zA-Z]"; 
break; 
case '2': 
regex += "[a-z]"; 
break; 
case '3': 
regex += "[A-Z]"; 
break; 
case '4': 
regex += "[!-/:-@/[-`{-~]"; 
break; 
case '5': 
regex += "[/u4E00-/u9FA5]"; 
break; 
case '6': 
regex += "[a-zA-Z0-9]"; 
break; 
case '7': 
regex += "[a-z0-9]"; 
break; 
case '8': 
regex += "[A-Z0-9]"; 
break; 
case '9': 
regex += "[!-~]"; 
break; 
case '10': 
regex += "[0-9/u4E00-/u9FA5]"; 
break; 
case '11': 
regex += "[a-z!-/:-@/[-`{-~]"; 
break; 
case '12': 
regex += "[A-Z!-/:-@/[-`{-~]"; 
break; 
case '13': 
regex += "[a-zA-Z!-/:-@/[-`{-~]"; 
break; 
case '14': 
regex += "[a-z/u4E00-/u9FA5]"; 
break; 
case '15': 
regex += "[A-Z/u4E00-/u9FA5]"; 
break; 
case '16': 
regex += "[a-zA-Z/u4E00-/u9FA5]"; 
break; 
case '17': 
regex += "[/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '18': 
regex += "[/u4E00-/u9FA5!-~]"; 
break; 
case '19': 
regex += "[a-z/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '20': 
regex += "[A-Z/u4E00-/u9FA5!-/:-@/[-`{-~]"; 
break; 
case '100': 
regex += "[/s/S]"; 
break; 
default: 
alert(matcherFlag + ":This type is not supported!"); 
} 
regex += this.isNotBlank(length) ? "{" + length + "}" : "+"; 
regex += "$"; 
var pattern = new RegExp(regex, ignoreCase ? "i" : ""); 
return pattern.test(input); 
}, 
/** 
* @description 中文校验 
* @param input 
* @return {boolean} 
*/ 
isChinese: function(input) { 
return /^[/u4E00-/u9FA5]+$/.test(input); 
}, 
/** 
* @description 去掉中文字符 
* @param input 
* @return {string|XML|void} 
*/ 
removeChinese: function(input) { 
return input.replace(/[/u4E00-/u9FA5]+/gm, ""); 
}, 
/** 
* @description 转义元字符 
* @param input 
* @return {*} 
*/ 
escapeMetacharacter: function(input) { 
var metacharacter = "^$()*+.[]|//-?{}|"; 
if(metacharacter.indexOf(input) >= 0) { 
input = "//" + input; 
} 
return input; 
}, 
/** 
* @description 转义字符串中的元字符 
* @param input 
* @return {*} 
*/ 
escapeMetacharacterOfStr: function(input) { 
return input.replace(/[/^/$/*/+/./|///-/?/{/}/|]/gm, "//$&"); 
}, 
/** 
* @description 增强字符串替换函数 
* @param input 
* @param oldStr 
* @param newStr 
* @return {string|XML|void} 
*/ 
replaceAll: function(input,oldStr,newStr) 
{ 
return  input.replace(new RegExp(oldStr,"gm"),newStr); 
} 
};

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/18087.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论