javaScript字符串工具類StringUtils詳解
更新時間:2017年12月08日 09:19:19 作者:老鼠擰刀滿街找貓
這篇文章主要為大家詳細介紹了javaScript字符串工具類StringUtils,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了javaScript字符串工具類的具體代碼,供大家參考,具體內(nèi)容如下
StringUtils = { isEmpty: function(input) { return input == null || input == ''; }, isNotEmpty: function(input) { return !this.isEmpty(input); }, isBlank: function(input) { return input == null || /^\s*$/.test(input); }, isNotBlank: function(input) { return !this.isBlank(input); }, trim: function(input) { return input.replace(/^\s+|\s+$/, ''); }, trimToEmpty: function(input) { return input == null ? "" : this.trim(input); }, startsWith: function(input, prefix) { return input.indexOf(prefix) === 0; }, endsWith: function(input, suffix) { return input.lastIndexOf(suffix) === 0; }, contains: function(input, searchSeq) { return input.indexOf(searchSeq) >= 0; }, equals: function(input1, input2) { return input1 == input2; }, equalsIgnoreCase: function(input1, input2) { return input1.toLocaleLowerCase() == input2.toLocaleLowerCase(); }, containsWhitespace: function(input) { return this.contains(input, ' '); }, //生成指定個數(shù)的字符 repeat: function(ch, repeatTimes) { var result = ""; for(var i = 0; i < repeatTimes; i++) { result += ch; } return result; }, deleteWhitespace: function(input) { return input.replace(/\s+/g, ''); }, rightPad: function(input, size, padStr) { return input + this.repeat(padStr, size); }, leftPad: function(input, size, padStr) { return this.repeat(padStr, size) + input; }, //首小寫字母轉(zhuǎn)大寫 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(); }); }, //首大寫字母轉(zhuǎn)小寫 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(); }); }, //大寫轉(zhuǎn)小寫,小寫轉(zhuǎn)大寫 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(); } }); }, //統(tǒng)計含有的子字符串的個數(shù) 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; }, //只包含字母 isAlpha: function(input) { return /^[a-z]+$/i.test(input); }, //只包含字母、空格 isAlphaSpace: function(input) { return /^[a-z\s]*$/i.test(input); }, //只包含字母、數(shù)字 isAlphanumeric: function(input) { return /^[a-z0-9]+$/i.test(input); }, //只包含字母、數(shù)字和空格 isAlphanumericSpace: function(input) { return /^[a-z0-9\s]*$/i.test(input); }, //數(shù)字 isNumeric: function(input) { return /^(?:[1-9]\d*|0)(?:\.\d+)?$/.test(input); }, //小數(shù) isDecimal: function(input) { return /^[-+]?(?:0|[1-9]\d*)\.\d+$/.test(input); }, //負(fù)小數(shù) isNegativeDecimal: function(input) { return /^\-?(?:0|[1-9]\d*)\.\d+$/.test(input); }, //正小數(shù) isPositiveDecimal: function(input) { return /^\+?(?:0|[1-9]\d*)\.\d+$/.test(input); }, //整數(shù) isInteger: function(input) { return /^[-+]?(?:0|[1-9]\d*)$/.test(input); }, //正整數(shù) isPositiveInteger: function(input) { return /^\+?(?:0|[1-9]\d*)$/.test(input); }, //負(fù)整數(shù) isNegativeInteger: function(input) { return /^\-?(?:0|[1-9]\d*)$/.test(input); }, //只包含數(shù)字和空格 isNumericSpace: function(input) { return /^[\d\s]*$/.test(input); }, isWhitespace: function(input) { return /^\s*$/.test(input); }, isAllLowerCase: function(input) { return /^[a-z]+$/.test(input); }, isAllUpperCase: function(input) { return /^[A-Z]+$/.test(input); }, defaultString: function(input, defaultStr) { return input == null ? defaultStr : input; }, defaultIfBlank: function(input, defaultStr) { return this.isBlank(input) ? defaultStr : input; }, defaultIfEmpty: function(input, defaultStr) { return this.isEmpty(input) ? defaultStr : input; }, //字符串反轉(zhuǎn) reverse: function(input) { if(this.isBlank(input)) { input; } return input.split("").reverse().join(""); }, //刪掉特殊字符(英文狀態(tài)下) removeSpecialCharacter: function(input) { return input.replace(/[!-/:-@\[-`{-~]/g, ""); }, //只包含特殊字符、數(shù)字和字母(不包括空格,若想包括空格,改為[ -~]) isSpecialCharacterAlphanumeric: function(input) { return /^[!-~]+$/.test(input); }, /** * 校驗時排除某些字符串,即不能包含某些字符串 * @param {Object} conditions:里面有多個屬性,如下: * * @param {String} matcherFlag 匹配標(biāo)識 * 0:數(shù)字;1:字母;2:小寫字母;3:大寫字母;4:特殊字符,指英文狀態(tài)下的標(biāo)點符號及括號等;5:中文; * 6:數(shù)字和字母;7:數(shù)字和小寫字母;8:數(shù)字和大寫字母;9:數(shù)字、字母和特殊字符;10:數(shù)字和中文; * 11:小寫字母和特殊字符;12:大寫字母和特殊字符;13:字母和特殊字符;14:小寫字母和中文;15:大寫字母和中文; * 16:字母和中文;17:特殊字符、和中文;18:特殊字符、字母和中文;19:特殊字符、小寫字母和中文;20:特殊字符、大寫字母和中文; * 100:所有字符; * @param {Array} excludeStrArr 排除的字符串,數(shù)組格式 * @param {String} length 長度,可為空。1,2表示長度1到2之間;10,表示10個以上字符;5表示長度為5 * @param {Boolean} ignoreCase 是否忽略大小寫 * conditions={matcherFlag:"0",excludeStrArr:[],length:"",ignoreCase:true} */ isPatternMustExcludeSomeStr: function(input, conditions) { //參數(shù) 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] = Bee.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); }, /** * @param {String} message * @param {Array} arr * 消息格式化 */ format: function(message, arr) { return message.replace(/{(\d+)}/g, function(matchStr, group1) { return arr[group1]; }); }, /** * 把連續(xù)出現(xiàn)多次的字母字符串進行壓縮。如輸入: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; }); }, /** * 校驗必須同時包含某些字符串 * @param {String} input * @param {Object} conditions:里面有多個屬性,如下: * * @param {String} matcherFlag 匹配標(biāo)識 * 0:數(shù)字;1:字母;2:小寫字母;3:大寫字母;4:特殊字符,指英文狀態(tài)下的標(biāo)點符號及括號等;5:中文; * 6:數(shù)字和字母;7:數(shù)字和小寫字母;8:數(shù)字和大寫字母;9:數(shù)字、字母和特殊字符;10:數(shù)字和中文; * 11:小寫字母和特殊字符;12:大寫字母和特殊字符;13:字母和特殊字符;14:小寫字母和中文;15:大寫字母和中文; * 16:字母和中文;17:特殊字符、和中文;18:特殊字符、字母和中文;19:特殊字符、小寫字母和中文;20:特殊字符、大寫字母和中文; * 100:所有字符; * @param {Array} excludeStrArr 排除的字符串,數(shù)組格式 * @param {String} length 長度,可為空。1,2表示長度1到2之間;10,表示10個以上字符;5表示長度為5 * @param {Boolean} ignoreCase 是否忽略大小寫 * conditions={matcherFlag:"0",containStrArr:[],length:"",ignoreCase:true} * */ isPatternMustContainSomeStr: function(input, conditions) { //參數(shù) var matcherFlag = conditions.matcherFlag; var containStrArr = conditions.containStrArr; var length = conditions.length; var ignoreCase = conditions.ignoreCase; //創(chuàng)建正則 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); }, //中文校驗 isChinese: function(input) { return /^[\u4E00-\u9FA5]+$/.test(input); }, //去掉中文字符 removeChinese: function(input) { return input.replace(/[\u4E00-\u9FA5]+/gm, ""); }, //轉(zhuǎn)義元字符 escapeMetacharacter: function(input) { var metacharacter = "^$()*+.[]|\\-?{}|"; if(metacharacter.indexOf(input) >= 0) { input = "\\" + input; } return input; }, //轉(zhuǎn)義字符串中的元字符 escapeMetacharacterOfStr: function(input) { return input.replace(/[\^\$\*\+\. \|\\\-\?\{\}\|]/gm, "\\$&"); } };
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- JS 對象(Object)和字符串(String)互轉(zhuǎn)方法
- JavaScript截取字符串的Slice、Substring、Substr函數(shù)詳解和比較
- js String對象中常用方法小結(jié)(字符串操作)
- js字符串的各種格式的轉(zhuǎn)換 ToString,F(xiàn)ormat
- js substring()字符串截取函數(shù)
- JavaScript字符串String和Array操作的有趣方法
- Javascript String 字符串操作包
- 幾個常用的JavaScript字符串處理函數(shù) - split()、join()、substring()和indexOf()
- Javascript類型系統(tǒng)之String字符串類型詳解
- JavaScript的String字符串對象常用操作總結(jié)
- js字符串類型String常用操作實例總結(jié)
相關(guān)文章
uniapp中uni.request(OBJECT)接口請求封裝實例代碼
在開發(fā)的時候經(jīng)常會用到前端請求后端接口,每次的請求都會出現(xiàn)地址不一樣,參數(shù)不一樣,方式不一樣等等情況,下面這篇文章主要給大家介紹了關(guān)于uniapp中uni.request(OBJECT)接口請求封裝的相關(guān)資料,需要的朋友可以參考下2022-12-12JavaScript聲明函數(shù)的5種方法小結(jié)
本文主要介紹了JavaScript聲明函數(shù)的5種方法小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02微信小程序?qū)崿F(xiàn)點擊按鈕移動view標(biāo)簽的位置功能示例【附demo源碼下載】
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)點擊按鈕移動view標(biāo)簽的位置功能,涉及微信小程序事件綁定與this.setData動態(tài)修改data數(shù)值進而改變view標(biāo)簽樣式的相關(guān)操作技巧,需要的朋友可以參考下2017-12-12JavaScript?Map?和?Object?的區(qū)別解析
在JavaScript中,Map 和 Object 看起來都是用鍵值對來存儲數(shù)據(jù),那么他們有什么不同呢,這篇文章主要介紹了JavaScript?Map?和?Object?的區(qū)別,需要的朋友可以參考下2022-08-08微信小程序內(nèi)拖動圖片實現(xiàn)移動、放大、旋轉(zhuǎn)的方法
這篇文章主要介紹了微信小程序內(nèi)拖動圖片實現(xiàn)移動、放大、旋轉(zhuǎn)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09