preface

Most people find this one rather messy (I do too (✿◡‿◡). After all, there are so many metacharacters that they look unsystematic and hard to remember. Therefore, this article will not say so many official words, we will talk in plain English to regularize, in order to strengthen your memory, in the article made three summaries, to deepen your memory. This article belongs to js regular article in a very basic article, the later will continue to update, the article is insufficient in the place also hope that the big guys give more advice (my dish dig foot), if you think this article is helpful, also hope you can give the article a thumbnail,

For more technical articles, you can follow my public number

What is a regular expression

Regular expressions (RegExp): A rule for manipulating strings.

Regex is basically a rule that uses different symbols to represent different meanings to make some matching patterns. The target is either a string matching character or the position of the matching character

Creating regular expressions

JavaScript supports regular expressions through the built-in object RegExp. There are two ways to instantiate this object: constructors and literals

Now let’s talk about how to use these two methods to create regular expressions

Constructor

RegExp is an object, just like Date. When using RegExp, you need to instantiate the object with a new one

let reg = new RegExp(a);The first argument is the body of the regular expression (the regular expression we wrote).
// The second argument is the modifier (optional)
Copy the code

Take a look at the following example:

let str='My name is symbol Lu';
let reg =new RegExp("a");// The simplest regular expression will match the letter A
let res=reg.test(str);The test() method retrieves the specified value in the string. The return value is true or false
console.log(res);//true
Copy the code

In the code above, the re is used to match the letter A and the test() method in the RegExp object is used to retrieve the specified character A in the string. The string My name is symbol Lu contains the character A and returns true.

Now that you’ve seen the RegExp object with one parameter, let’s look at the RegExp object with two parameters:

let str='My name is symbol Lu';
let reg=new RegExp("A"."i");// The I in the second argument is a modifier, indicating that the match is case insensitive
let res=reg.test(str);
console.log(res);//true
Copy the code

Let reg=new RegExp(“A”,” I “); let reg=new RegExp(“A”,” I “); The second argument to this code, I, is a modifier, which is case-insensitive. The string above has a and the re is a. A and A are the same because of the modifier I, so it returns true.

Literal mode

Its syntax is as follows:

let reg=/pattern/fages;
// This is his syntax, where pattern corresponds to the first argument in the constructor mode (regular expression body).
// Fages correspond to the second argument in constructor mode (modifier)
Copy the code

Next, let’s use the literal approach and then complete the two small examples of the constructor approach above to see the direct similarities and differences

let str='My name is symbol Lu';
let reg =/a/;// The simplest regular expression will match the letter A
let res=reg.test(str);The test() method retrieves the specified value in the string. The return value is true or false
console.log(res);//true
Copy the code
let str='My name is symbol Lu';
let reg =/A/i;// The simplest regular expression will match the letter A
let res=reg.test(str);The test() method retrieves the specified value in the string. The return value is true or false
console.log(res);//true
Copy the code

What is the difference between the two methods??

  1. In JS, regular expressions are declared in two ways for\d\D(later will talk about the ha 😄) and other matching patterns

Constructor: needs to be escaped, for example: let reg=new RegExp(“\\d”);

Literal ways: do not need to escape, for example: let reg=/\d/;

  1. Respective advantages

Constructor method: support string concatenation, support variables, more flexible, such as:

let str="dsf12345678fdfa123456hggf123";
let variable='{2, 6}';
let reg=new RegExp("\\d"+variable);
let res=str.match(reg);
console.log(res)
//Tips: This is just an example, you can use it in this way, you can use it according to your business needs
Copy the code

Literal: For fixed expressions, writing is faster and more intuitive. Such as: the let reg = / \ d {6} /

Tips: the difference between the inside of the example of the re do not understand it doesn’t matter, the following will chat, here just for example 🌰

The modifier

In the above example, we used the modifier, what is the purpose of the modifier?

There are three common modifiers (I, G, m, etc.) that can occur at the same time and in no order (gi and IG are the same)

The modifier instructions
i IgnoreCase ignores case matching
g Global Indicates a global match. That is, the match continues until the end
m Multiline matching, that is, the matching does not stop until the end of a line break

Method of the RegExp object

RegExp is an object that contains methods. There are three common methods in RegExp: test(), exec(), and compile().

test()

The test() method retrieves the specified value in the string. The return value is true or false.

let str='My name is symbol Lu';
let reg =/a/;// The simplest regular expression will match the letter A
let res=reg.test(str);The test() method retrieves the specified value in the string. The return value is true or false
console.log(res);//true
Copy the code

The string we want to retrieve My name is symbol Lu contains our specified string A so returns true

exec()

The exec() method retrieves the specified value in the string. Returns an array containing the matching results. If no match is found, the return value is null

let str='My name is symbol Lu';
let reg =/z/;
let res=reg.exec(str);
console.log(res);//null
Copy the code

The string we are retrieving My name is symbol Lu does not contain the string we specified z did not find a match so null is returned

let str='My name is symbol Lu and I love to write code';
let reg =/I/g;// Review the modifiers
let res=reg.exec(str);
console.log(res);
Copy the code

We retrieve globally the specified character I in the string My Name is symbol Lu and I love to write code

String contains I so returns an array of matching results

compile()

The compile() method is used to change the RegExp. You can change the retrieval mode, and you can add or remove the second parameter.

let str='My name is symbol Lu and I love to write code';
let reg =/I/g;
console.log(reg.test(str));//true
reg.compile("W");
console.log(reg.test(str));//false
Copy the code

Since there is an “I” in the string but no “W”, the first output is true and the second output is false

In the string My name is symbol Lu and I love to write code the first retrieved character is I so the first output is true, then reg.compile(“W”); Change the character to be retrieved in the regular expression to W but there is no character W in the string so the second output is false.

We haven’t started the regular js rules yet. I can’t wait. Just a minute

The way you can use a re in a string (common)

match()

The match() method uses regular expressions to find the string and returns the result as an array

let str="132dfdf465gaer465fgds654gfa";// Use a random string
let reg=/\d+/g;// What is \d in the following example
let res=str.match(reg);
console.log(res);/ / / "132", "465", "465", "654"]
Copy the code

Use the match () method to the string in one or more of the 132 dfdf465gaer465fgds654gfa global modifier (g) digital search, will return an array with the results of search.

Here is the code without the g modifier:

let str="132dfdf465gaer465fgds654gfa";
let reg=/\d+/;
let res=str.match(reg);
console.log(res)
/ / result: [" 132 ", the index: 0, input: "132 dfdf465gaer465fgds654gfa groups: undefined]
Copy the code

Did not use a modifier g global search, that is, as long as there is a regular conditions to find the characters, will be over in a search, in the above case, 132 is a one or more Numbers, satisfy the search conditions So ended the regular search, will find the results to return in the form of an array.

By comparing these two cases, do you feel that you have a better understanding of the modifier G? Haha

replace()

The replace() method replaces all occurrences of oldChar characters in a string with newChar characters and returns the replaced new string

let str="SymbolLu";
let reg=/Lu/;
let res=str.replace(reg,"Lu");
console.log(res)/ / Symbol lu
Copy the code

For the string SymbolLu, we used the re /Lu/ to match the Lu character.

So the output is Symbol Lew.

Here are some rules for creating RegExp objects: 👇👇👇👇👇…

Some common rules

These rules are some special characters composed of rules, you do not always think remember, maybe this is one of the reasons why you think the regular is difficult, it does not matter, let’s go on to look at a little bit of simple (a little loaded force

The chestnut 🌰

let str='521 symbol Lou 2121';// self-absorbed, ha ha 😄
// To recap, there are two ways to create a re
//let regExp=new RegExp('[0-9]+','g');
let regExp =/[0-9]+/g;
// To refresh your memory, the Math method returns as an array that matches the regular expression
console.log(str.match(regExp));
// Result is ["521", "2121"]
Copy the code

In the previous example 🌰, the re [0-9] in [0-9]+ matches any number from 0 to 9. It can also be represented by \d

+ is a quantifier that occurs at least once, or more than once

/[0-9]+/g = /[0-9]+/g = /[0-9]+/g = /[0-9] The result of the first match is 521 and the result of the second match is 2121 (remember we are using g global match here).

This 🌰 is finished, let’s have another 🌰

let str="1232546qwe1323147";// Deploy the character ☺
 console.log(str.match(/[0-9]+/g));
// Result is ["1232546", "1323147"]
// The result is the same as the following.
console.log(str.match(/123/g));
console.log(str.match(/12+/g));
console.log(str.match(/[123]/g));
Copy the code

Thinking… (ˇ result ˇ) want to ~

Okay, let’s move on to the results…

console.log(str.match(/123/g));/ / / "123"
console.log(str.match(/12+/g));/ / / "12"
console.log(str.match(/[123]/g));//["1", "2", "3", "2", "1", "3", "1"]
Copy the code

Using str.match(/123/g) in the string 1232546qWE1323147 only matches the character 123 (the beginning of the string), so the result is [“123”]; Str.match (/12+/g) matches a string that has been globally matched one or more times. The result is [“12”].

console.log(str.match(/[123]/g)); The result of this one feels different from your answer, that’s ok, let’s talk about it

[] indicates that any character in the braces can be matched

So any one of the 1’s, 2’s and 3’s that match will output its result, global match

So the result is: [” 1 “, “2”, “3”, “2”, “1”, “3”, “2”, “3”, “1”]

I can match any character that appears, so what if I don’t let it appear, which is to exclude it,

Example:

let str="asd42134dfjasdjfi3458fasdn";// A random string
// To refresh your memory, the Math method returns as an array that matches the regular expression
console.log(str.match(/[^0-9]+/g));
// result [" asD ", "dfJASdjfi "," fasDN "]
Copy the code

All characters in [^] braces are excluded

The above string is composed of letters and arrays. [0-9] represents numbers. [^0-9] represents not numbers.

The [^0-9]+ re is multiple non-numeric characters and we used global matching to get the result above

Ok, here, let’s make a summary of the above content, and deepen the impression.

Summary ———- impression +1

  • There are two ways to create a re:
//1. Constructor method
let reg = new RegExp("A"."i");
The first argument is the body of the regular expression (the regular expression we wrote).
// The second argument is the modifier (optional)
//2
let reg =/A/i;// The simplest regular expression will match the letter A
//let reg=/pattern/fages;
// This is his syntax, where pattern corresponds to the first argument in the constructor mode (regular expression body).
// Fages correspond to the second argument in constructor mode (modifier)
Copy the code
  • The modifier ——– there is no sequential order

Can occur simultaneously and in no order (i.e. gi and IG are the same)

The modifier instructions
i IgnoreCase ignores case matching
g Global Indicates a global match. That is, the match continues until the end
m Multiline matching, that is, the matching does not stop until the end of a line break
  • Method of the RegExp object
  1. The test() method retrieves the specified value in the string. The return value is true or false.
  2. The exec() method retrieves the specified value in the string. Returns an array containing the matching results. If no match is found, the return value is null.
  3. The compile() method is used to change the RegExp by changing the retrieval mode, or by adding or removing a second parameter.
  • Common methods of regex can be used in strings
  1. The match() method uses regular expressions to find the string and returns the result as an array.
  2. The replace() method replaces all occurrences of oldChar characters in a string with newChar characters and returns the replaced new string.
  • Part of the rules
  1. [0-9] : Matching any number from 0 to 9 can also be used \dsaid
  2. + : is aquantifiers(We’ll talk about quantifiers later),Indicates at least one occurrence or multiple occurrences
  3. []: indicates thatInside the bracesAny characterIf you can match it, it’s ok
  4. (^): Any character inside braces cannot appear with[]Is the opposite

quantifiers

Quantifiers, as their name suggests, are matched quantifiers, i.e. the number of occurrences of a character (or group of characters), which can be zero, one, multiple, n, and so on. Let’s talk about quantifiers from less to more using 🌰

example

let str="1232546qwe1323147";
let reg=/8*/g;
//let reg=/8{0,}/g;
The test() method retrieves the specified value in a string. The return value is true or false
console.log(reg.test(str));//true
Copy the code

Here we use the quantifier * : represents zero to (or more than) times, or {0,} instead, in our example there is no 8 in the string 1232546qWE1323147

That is, 8 occurs zero times in the string and returns true when test() is used

Here’s another example: 🌰

let str="1232546qwe1323147";
let reg=/ 7? /g;
/ / let reg = / 7 {0, 1} / g;
console.log(reg.test(str));//true
Copy the code

We’re using quantifiers here, right? : represents zero to (or) once, or {0,1} can be used instead. In our example, the string 1232546qwe1323147 has 7 appearing once, satisfying zero to (or) once

So test() returns true

example

let str="1232546qwe1323147";
let reg=/8+/g;
// let reg=/8{1,}/g;
console.log(reg.test(str));//false
Copy the code

Here we use the quantifier +, which we used in the previous example: it represents one to (or more than) times, and can be replaced with {1,}. In our example the string 1232546qWE1323147 has no 8

That is, 8 occurs zero times in the string, not once to (or more than once, so test() returns false

We have talked zero to many times, zero to one and one to many, can you determine his number?

Of course the answer is yes! Let’s go straight to the example

let str="1232546qwe132311147";
let reg=/1{3}/g;
console.log(reg.test(str));//true  
Copy the code

{n} Specifies n times of matching. For example, {18} indicates 18 consecutive matches

To try to

{n,} matches at least n times. For example, {1,} indicates that the match is at least once

{n,m} matches at least n times and at most m times. For example, {1,7} matches at least 1 times and at most 7 times

This two quantifier small case, you can write examples to understand (try more, more practice oh)

Scope of the class

This is one of my memorization rules that represents ranges one by one for example, 0, 9 is a range, a, z is a range

[0-9] is the abbreviation for [0123456789]. It can also be used as \ D. We are smart enough to think of letters

The regular for the range a and z is that [a-z] is the lowercase letter abcd….. Z, that’s capital A and z is the same thing, that’s right

[a-z], there’s actually another [A-za-z] which is lowercase A Z and uppercase A Z

let str="45drfgadf44545g455sd454fgs44542df415g445";// Another random string
let reg=/[0-9]+/g;
//let reg=/\d+/g;
// To refresh your memory, the Math method returns as an array that matches the regular expression
let res=str.match(reg);
console.log(res);/ / / "45", "44545", "455", "454", "44542", "415", "445"]
Copy the code

/ [0-9] + 45 drfgadf44545g455sd454fgs44542df415g445 / g to the string in one or more of the digital global matching ([0-9] number, + one or more times, g global match). Str.match (reg) returns the matched result as an array, so the result is [“45”, “44545”, “455”, “454”, “44542”, “415”, “445”]

Then go on to chestnut 🌰

let str="546dfdsSFGDSF1232qweai Love front end";
let reg=/[0-9a-zA-Z]+/g;
// To recap, replace() replaces the matched character with a new string
let res=str.replace(reg, 'Symbol.);
console.log(res);//Symbol Symbol
Copy the code

/[0-9a-zA-z]+/g Perform global matching for one or more occurrences of numbers and letters, So the matching character in the string 546dfdsSFGDSF1232qweai is 546dfdsSFGDSF1232qweai, followed by str.replace(reg, ‘Symbol ‘); Replace the matching character with Symbol so the output is the Symbol Symbol front end

Summary ———- impression +2

-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - -- -- -- -- -- amount of words -- -- -- -- -- -- -- -- -- -- - * matches the sub-expression in front of zero or more, 0 to more, you can use {0} instead of + matched subexpression once or many times, in front of more than 1 to, you can use {1} instead? Match the preceding subexpression zero or once, 0 or 1, you can use {0,1} instead of {n} matching a certain n times, such as {18}, continuous matching 18 times {n,} at least n times, such as {2,}, which means at least 2 times {n,m} at least n times and at most m times, Such as {1, 7} represents the least matching 1 up to seven times -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- fan -- -- -- -- -- -- -- round -- -- -- -- -- -- -- -- -- the class -- -- -- -- -- -- -- -- -- -- -- - [0-9] represent Numbers can be used \ [a-z] d said said lowercase letters a to z [a-z] Indicates uppercase letters A to Z [A-za-z] Indicates letters A to Z and A to Z [0-9A-za-z] indicates numbers and lettersCopy the code

Boundary classes

The boundary is the threshold or something like that, the beginning, the end these are also what some of you like to call positional classes that have to do with location, and the next boundary classes we’re going to talk about are the beginning and the end

At the beginning

^ Matches the start of the input string (which character or what to start with)

Let’s go straight to the example

let tel='17811114455';// For privacy, 😄 is replaced with 1 in the middle
// A classic case to verify whether the mobile phone number is valid
let reg=/^1[34578]\d{9}/g;
if(reg.test(tel)){The ////test() method retrieves the specified value in the string. The return value is true or false
  console.log("Cell phone number legal.")}else{
  console.log("Cell phone number is illegal.")}// Result: The mobile number is valid
Copy the code

/^1[34578]\d{9}/g start with 1, the second character is any of 3,4,5,7,8, followed by 9 digits, (a total of 11 digits) for global matching, string 17811114455 must start with 1, Reg. Test (tel) is true, and the phone number is valid

At the end

$matches the end position of the input string (which character or what to end with)

Example:

let fileName='68468fgdsdfs.jpg';
let reg=/\.jpg$/g;// It needs to be changed. It is a wildcard (more on that later) so it needs to be changed
if(reg.test(fileName)){
  console.log("Picture legal")}else{
  console.log("Picture is illegal.")}// Result: the image is valid
Copy the code

/\.jpg$/g matches characters ending in.jpg ($), because. Is a wildcard character, so use \

Transpose. So that it represents a dot (.) instead of a wildcard; The string 68468fgdsdfs.jpg satisfies the.jpg end, so reg.test(fileName) is true, and the output is a valid image

In fact, there are two more in the boundary class are word boundary and non-word boundary, for easy memory, they are put in the predefined class to talk about

Predefined classes

Digital digital

In the previous section, we know that [0-9] represents a number, which can be represented by \d

[^] is the opposite of the curly braces and [^ 0-9] is a non-numeric representation in js regex

Non-numeric can be denoted by \D (did you notice that \D and \D have opposite ranges)

All right, here’s an example

let str="123qwe45lu7876";
let reg=/\d+/g;
let res=str.match(reg);// To refresh your memory, the Math method returns as an array that matches the regular expression
console.log(res)// Result: ["123", "45", "7876"]
Copy the code
let str="123qwe45lu7876";
let reg=/\D+/g;
let res=str.match(reg);// To refresh your memory, the Math method returns as an array that matches the regular expression
console.log(res)// result: ["qwe", "lu"]
Copy the code

Word for word

English words have numerals \w matches any word character (digits, letters, underscores), equivalent to [A-za-z0-9_]

let str="dfa425@fg*gfd+djfakj#df_jla";
let reg=/\w+/g;
let res=str.match(reg);
console.log(res)// ["dfa425", "fg", "gfd", "djfakj", "df_jla"]
Copy the code

The string dfa425@fg* GFD +djfakj#df_jla contains characters such as numbers, letters, underscores, and special symbols. As discussed above, the word (\w) contains digits, letters, and underscores. In the case above, /\w+/g Globally matches words (numbers, letters, underscores) that occur once or more, so the result is [“dfa425”, “fg”, “GFD “,” djFAKJ “, “df_jla”].

To recall the previous rule about numbers, \d means numbers and \d means non-numbers

So, \w is word, \w is non-word equivalent to [^ A-za-z0-9_] Does that make it easier to ☺?

let str="dfa425@fg*gfd+djfakj#df_jla";
let reg=/\W+/g;
let res=str.match(reg);
console.log(res)/ / / "@", "*", "+", "#"]
Copy the code

This matches a non-word, so it returns [“@”, “*”, “+”, “#”]

Chinese

[u4e00-u9fa5]/ [u4e00-u9fa5]/ [u4e00-u9fa5]

/\p{Unified_Ideograph}/u is correct, does not need maintenance, matches all Chinese characters.

blank

ASCII table

Whitespace includes the keyboard TAB key, line feed, carriage return, page feed, and space. You can refer to the ASCII table above where TAB is \t, line feed is \n, carriage return is \r, page feed is \f, and space is \v.

\s = [\t\n\r\f\v] [\t\n\r\f\v]

In the same way, \S means non-space or blank space.

let str="Symbol.";
function trim(str){
  return str.replace(/\s/g."");
}
console.log(str,"The original string");
console.log(trim(str),"String without whitespace");
// The result is shown below
Copy the code

The wildcard

. Matches any character (except carriage return \r and newline \f)

Word boundary

Word boundaries in the regular expression (string beginning, end, Spaces, commas, periods, etc) is expressed in \ b, refers to the position, between the word and the word is not refers to the character, or the character \ w or between the end position, with the beginning of the string, from the experience of the article before \ b match wrong word boundaries

let str="sdfgsd fldy [js]_fasd.exerqp-0441";
let reg=/\b/g;
let res=str.replace(reg,"*");
console.log(str,"The original string")
console.log(res,"Replaced string");
👇👇👇👇👇
Copy the code

In the code above, take the stringsdfgsd fldy [js]_fasd.exerqp-0441Word boundaries in\bMatches to the content used*

The word boundary is not very easy to understand, so it is not put in front of the scope class and we talk about). Next, let’s look at the code \B (non-word boundary)

let str="sdfgsd fldy [js]_fasd.exerqp-0441";
let reg=/\B/g;
let res=str.replace(reg,"*");
console.log(str,"The original string")
console.log(res,"Replaced string");
👇👇👇👇👇
Copy the code

The difference between \b (word boundary) and \b (non-word boundary) should be carefully considered here.

Knowing/B (word boundary) and \B (non-word boundary), next, let’s practice with a small case, come on!!

let str = "My name is symbol Lu";
let reg=/\b\w+\b/g;
let res= str.match(reg);// Extract all the words in the string
console.log(res)// result ["My", "name", "is", "symbol", "Lu"]
Copy the code

In the above case, /\b\w+\b/g matches words that occur once or more from globally (words are preceded by word boundaries), so the output is

[” My “, “name”, “is”, “symbol”, “Lu”], actually use / \ w + / g are matching the result of the same.

Summary —– impression +3

-- -- -- -- -- -- -- -- -- -- the beginning and end -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- ^ matches the starting position of the input string which began (to which character or) $matches the end of the input string position (to which character or what the end) -- -- -- -- -- -- -- -- -- -- - digital -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - [0-9] said is digital, you can use \ d said [^ 0-9] said the Numbers, Can use \ D said (memory) in pairs -- -- -- -- -- -- -- -- -- -- - the words -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- \ w match any word character (Numbers, letters, underline), Equivalent to [A Za - z0-9 _] \ W matching are words -- -- -- -- -- -- -- -- -- -- -- -- Chinese -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - / / \ u4e00 - \ u9fa5 / regular can match Chinese, remember that is in Chinese, matching of Chinese characters is not correct; /\p{Unified_Ideograph}/u is correct, does not need maintenance, matches all Chinese characters. -- -- -- -- -- -- -- -- -- -- -- -- blank -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- \ s equal to [\ t \ n \ r \ f \ v] is a space and blank \ s match of blank Spaces and the -- -- -- -- -- -- -- -- -- -- -- -- wildcard -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -. Matches any character (except carriage return \r and newline \f) ------------ word boundaries ------------------ \b matches word boundaries (beginning, end of string, Spaces, commas, periods, etc.) is the position between words and non-words \b matches non-word boundariesCopy the code

Js regular expression

User name re

User name regular, 4 to 16 characters (letters, digits, underscores, minus signs)

let reg = / ^ [a - zA - Z0 - _ - 9] $/ dec {4};
Copy the code

Email regular

let reg = / ^ ([A Za - z0-9 _ \ - \]) + \ @ ([A - Za - z0-9 _ \ - \]) + \. ([A Za - z] {2, 4}) $/;
Copy the code

Mobile phone number regular

let reg = /^1[34578]\d{9}$/; 
Copy the code

Id regular

Id number (18 digits) is regular

let reg= /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
Copy the code

QQ number of regular

QQ number regular, 5 to 11 digits

let reg = / ^ (1-9] [0-9] {4, 10} $/;
Copy the code

Microsignal regularization

Micro signal regular, 6 to 20 characters, beginning with a letter, letter, number, minus sign, underscore

let reg = / ^ [a zA - Z] ([- _a - zA - Z0-9] {5} 3) + $/;
Copy the code

China Postcode

China postcode is 6 digits)

let reg=/[1-9]\d{5}(? ! \d)/;
Copy the code

Remove space before and after

let str=' SymbolLu ';
function trim(str){
    let reg=/^\s+|\s+$/g;
    return str.replace(reg,' ');
};
console.log(trim(str))
Copy the code

History oliver

  1. Js garbage collection mechanism principle to you talk clearly

  2. ES11 is here. Why don’t you check it out

  3. Second understand js scope and scope chain