📄 regexp.js
字号:
function(sep) { if ( sep == "" ) { return "(0|[1-9]\\d*)"; } return "(0|[1-9]\\d{0,2}([" + sep + "]\\d{3})*)"; } ); var numberRE; // integer RE return (signRE + numberRE);}/** Builds a regular expression to match a real number in exponential notation. @param flags An object. flags.places The integer number of decimal places. If not given, the decimal part is optional and the number of places is unlimited. flags.decimal A string for the character used as the decimal point. Default is ".". flags.exponent Express in exponential notation. Can be true, false, or [true, false]. Default is [true, false], (i.e. will match if the exponential part is present are not). flags.eSigned The leading plus-or-minus sign on the exponent. Can be true, false, or [true, false]. Default is [true, false], (i.e. will match if it is signed or unsigned). flags in regexp.integer can be applied. @return A string for a regular expression for a real number.*/dojo.regexp.realNumber = function(flags) { // assign default values to missing paramters flags = (typeof flags == "object") ? flags : {}; if (typeof flags.places != "number") { flags.places = Infinity; } if (typeof flags.decimal != "string") { flags.decimal = "."; } if (typeof flags.exponent == "undefined") { flags.exponent = [true, false]; } if (typeof flags.eSigned == "undefined") { flags.eSigned = [true, false]; } // integer RE var integerRE = dojo.regexp.integer(flags); // decimal RE var decimalRE = ""; if ( flags.places == Infinity) { decimalRE = "(\\" + flags.decimal + "\\d+)?"; } else if ( flags.places > 0) { decimalRE = "\\" + flags.decimal + "\\d{" + flags.places + "}"; } // exponent RE var exponentRE = dojo.regexp.buildGroupRE(flags.exponent, function(q) { if (q) { return "([eE]" + dojo.regexp.integer({signed: flags.eSigned}) + ")"; } return ""; } ); // real number RE return (integerRE + decimalRE + exponentRE);}/** Builds a regular expression to match a monetary value. @param flags An object. flags.signed The leading plus-or-minus sign. Can be true, false, or [true, false]. Default is [true, false], (i.e. will match if it is signed or unsigned). flags.symbol A currency symbol such as Yen "�", Pound "�", or the Euro sign "�". Default is "$". For more than one symbol use an array, e.g. ["$", ""], makes $ optional. flags.placement The symbol can come "before" the number or "after". Default is "before". flags.separator The character used as the thousands separator. The default is ",". flags.cents The two decimal places for cents. Can be true, false, or [true, false]. Default is [true, false], (i.e. will match if cents are present are not). flags.decimal A string for the character used as the decimal point. Default is ".". @return A string for a regular expression for a monetary value.*/dojo.regexp.currency = function(flags) { // assign default values to missing paramters flags = (typeof flags == "object") ? flags : {}; if (typeof flags.signed == "undefined") { flags.signed = [true, false]; } if (typeof flags.symbol == "undefined") { flags.symbol = "$"; } if (typeof flags.placement != "string") { flags.placement = "before"; } if (typeof flags.separator != "string") { flags.separator = ","; } if (typeof flags.cents == "undefined") { flags.cents = [true, false]; } if (typeof flags.decimal != "string") { flags.decimal = "."; } // build sign RE var signRE = dojo.regexp.buildGroupRE(flags.signed, function(q) { if (q) { return "[-+]"; } return ""; } ); // build symbol RE var symbolRE = dojo.regexp.buildGroupRE(flags.symbol, function(symbol) { // escape all special characters return "\\s?" + symbol.replace( /([.$?*!=:|\\\/^])/g, "\\$1") + "\\s?"; } ); // number RE var numberRE = dojo.regexp.integer( {signed: false, separator: flags.separator} ); // build cents RE var centsRE = dojo.regexp.buildGroupRE(flags.cents, function(q) { if (q) { return "(\\" + flags.decimal + "\\d\\d)"; } return ""; } ); // build currency RE var currencyRE; if (flags.placement == "before") { currencyRE = signRE + symbolRE + numberRE + centsRE; } else { currencyRE = signRE + numberRE + centsRE + symbolRE; } return currencyRE;}/** A regular expression to match US state and territory abbreviations. @param flags An object. flags.allowTerritories Allow Guam, Puerto Rico, etc. Default is true. flags.allowMilitary Allow military 'states', e.g. Armed Forces Europe (AE). Default is true. @return A string for a regular expression for a US state.*/dojo.regexp.us.state = function(flags) { // assign default values to missing paramters flags = (typeof flags == "object") ? flags : {}; if (typeof flags.allowTerritories != "boolean") { flags.allowTerritories = true; } if (typeof flags.allowMilitary != "boolean") { flags.allowMilitary = true; } // state RE var statesRE = "AL|AK|AZ|AR|CA|CO|CT|DE|DC|FL|GA|HI|ID|IL|IN|IA|KS|KY|LA|ME|MD|MA|MI|MN|MS|MO|MT|" + "NE|NV|NH|NJ|NM|NY|NC|ND|OH|OK|OR|PA|RI|SC|SD|TN|TX|UT|VT|VA|WA|WV|WI|WY"; // territories RE var territoriesRE = "AS|FM|GU|MH|MP|PW|PR|VI"; // military states RE var militaryRE = "AA|AE|AP"; // Build states and territories RE if (flags.allowTerritories) { statesRE += "|" + territoriesRE; } if (flags.allowMilitary) { statesRE += "|" + militaryRE; } return "(" + statesRE + ")";}/** Builds a regular expression to match any International format for time. The RE can match one format or one of multiple formats. Format h 12 hour, no zero padding. hh 12 hour, has leading zero. H 24 hour, no zero padding. HH 24 hour, has leading zero. m minutes, no zero padding. mm minutes, has leading zero. s seconds, no zero padding. ss seconds, has leading zero. t am or pm, case insensitive. All other characters must appear literally in the expression. Example "h:m:s t" -> 2:5:33 PM "HH:mm:ss" -> 14:05:33 @param flags An object. flags.format A string or an array of strings. Default is "h:mm:ss t". flags.amSymbol The symbol used for AM. Default is "AM". flags.pmSymbol The symbol used for PM. Default is "PM". @return A string for a regular expression for a time value.*/dojo.regexp.time = function(flags) { // assign default values to missing paramters flags = (typeof flags == "object") ? flags : {}; if (typeof flags.format == "undefined") { flags.format = "h:mm:ss t"; } if (typeof flags.amSymbol != "string") { flags.amSymbol = "AM"; } if (typeof flags.pmSymbol != "string") { flags.pmSymbol = "PM"; } // Converts a time format to a RE var timeRE = function(format) { // escape all special characters format = format.replace( /([.$?*!=:|{}\(\)\[\]\\\/^])/g, "\\$1"); var amRE = flags.amSymbol.replace( /([.$?*!=:|{}\(\)\[\]\\\/^])/g, "\\$1"); var pmRE = flags.pmSymbol.replace( /([.$?*!=:|{}\(\)\[\]\\\/^])/g, "\\$1"); // replace tokens with Regular Expressions format = format.replace("hh", "(0[1-9]|1[0-2])"); format = format.replace("h", "([1-9]|1[0-2])"); format = format.replace("HH", "([01][0-9]|2[0-3])"); format = format.replace("H", "([0-9]|1[0-9]|2[0-3])"); format = format.replace("mm", "([0-5][0-9])"); format = format.replace("m", "([1-5][0-9]|[0-9])"); format = format.replace("ss", "([0-5][0-9])"); format = format.replace("s", "([1-5][0-9]|[0-9])"); format = format.replace("t", "\\s?(" + amRE + "|" + pmRE + ")\\s?" ); return format; }; // build RE for multiple time formats return dojo.regexp.buildGroupRE(flags.format, timeRE);}/** Builds a regular expression to match any sort of number based format. Use it for phone numbers, social security numbers, zip-codes, etc. The RE can match one format or one of multiple formats. Format # Stands for a digit, 0-9. ? Stands for an optional digit, 0-9 or nothing. All other characters must appear literally in the expression. Example "(###) ###-####" -> (510) 542-9742 "(###) ###-#### x#???" -> (510) 542-9742 x153 "###-##-####" -> 506-82-1089 i.e. social security number "#####-####" -> 98225-1649 i.e. zip code @param flags An object. flags.format A string or an Array of strings for multiple formats. @return A string for a regular expression for the number format(s).*/dojo.regexp.numberFormat = function(flags) { // assign default values to missing paramters flags = (typeof flags == "object") ? flags : {}; if (typeof flags.format == "undefined") { flags.format = "###-###-####"; } // Converts a number format to RE. var digitRE = function(format) { // escape all special characters, except '?' format = format.replace( /([.$*!=:|{}\(\)\[\]\\\/^])/g, "\\$1"); // Now replace '?' with Regular Expression format = format.replace(/\?/g, "\\d?"); // replace # with Regular Expression format = format.replace(/#/g, "\\d"); return format; }; // build RE for multiple number formats return dojo.regexp.buildGroupRE(flags.format, digitRE);}/** This is basically a utility function used by some of the RE generators. Builds a regular expression that groups subexpressions. The subexpressions are constructed by the function, re, in the second parameter. re builds one subexpression for each elem in the array a, in the first parameter. @param a A single value or an array of values. @param re A function. Takes one parameter and converts it to a regular expression. @return A string for a regular expression that groups all the subexpressions.*/dojo.regexp.buildGroupRE = function(a, re) { // case 1: a is a single value. if ( !( a instanceof Array ) ) { return re(a); } // case 2: a is an array var b = []; for (var i = 0; i < a.length; i++) { // convert each elem to a RE b.push(re(a[i])); } // join the REs as alternatives in a RE group. return "(" + b.join("|") + ")";}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -