search
HomeWeb Front-endJS TutorialJavaScript study notes (8) Regular expressions_basic knowledge

Basic concepts

A regular expression is a text pattern that includes both ordinary characters (for example, the letters between a and z) and special characters (called "metacharacters"). A pattern describes one or more strings to match when searching for text.

First of all, we recommend several regular expression editors
Debuggex: https://www.debuggex.com/
PyRegex:http://www.pyregex.com/
Regexper: http://www.regexper.com/

Regular expression is a search and string replacement operation. Regular expressions are widely used in text editors. For example, regular expressions are used:
[copy] Check whether the text contains the specified feature word
Find the position of matching feature words in the text
Extract information from text, such as: substring of string
Modify text

Description: Regular expressions are usually used for two tasks: 1. Verification, 2. Search/replace. When used for verification, it is usually necessary to add ^ and $ before and after to match the entire string to be verified; whether to add this limit when searching/replacing depends on the search requirements. In addition, it may also be necessary to add before and after b instead of ^ and $. The commonly used regular expressions listed in this table are not preceded or followed by any restrictions except for a few. Please handle them by yourself according to your needs.

Priority order

After a regular expression is constructed, it can be evaluated like a mathematical expression, that is, it can be evaluated from left to right and in an order of precedence. The following table lists the precedence order of the various regular expression operators from highest priority to lowest priority:

操作符 描述
转义符
(), (?:), (?=), [] 圆括号和方括号
*, , ?, {n}, {n,}, {n,m} 限定符
^, $, anymetacharacter 位置和顺序

Create regular expression

Constructing regular expressions is the same as creating mathematical expressions. That is, using a variety of metacharacters and operators to combine small expressions to create larger expressions.
A regular expression can be constructed by placing the various components of the expression pattern between a pair of delimiters.

For JScript, the delimiter is a pair of forward slash (/) characters. For example:
/expression/

For VBScript, a pair of quotation marks ("") is used to determine the boundaries of the regular expression. For example:

Copy code The code is as follows:

"expression"

Let’s look at an example

Copy code The code is as follows:

//Whether the matching account is legal (starting with a letter, 5-16 bytes allowed, alphanumeric underscores allowed

var re =new RegExp("^[a-zA-Z][a-zA-Z0-9_]{5,19}$");
if(re.test(aaaa)){
alert("Correct format");
}else{
alert("Format error");
}

The components of a regular expression can be a single character, a collection of characters, a range of characters, a selection between characters, or any combination of all these components.

Commonly used regular expressions

Regular expression matching Chinese characters: [u4e00-u9fa5]
Comment: Matching Chinese is really a headache. With this expression, it will be easier

Match double-byte characters (including Chinese characters): [^x00-xff]
Comment: Can be used to calculate the length of a string (the length of a double-byte character counts as 2, and the length of an ASCII character counts as 1)

Regular expression matching blank lines: ns*r
Comment: Can be used to delete blank lines

Regular expression matching HTML tags: ]*>.*?1>|<.>
Comment: The version circulating on the Internet is too bad. The above one can only match part of it, and it is still powerless for complex nested tags

Regular expression matching leading and trailing whitespace characters: ^s*|s*$
Comment: It can be used to delete whitespace characters (including spaces, tabs, form feeds, etc.) at the beginning and end of the line. A very useful expression

Regular expression matching email addresses: w ([- .]w )*@w ([-.]w )*.w ([-.]w )*
Comment: Very useful for form validation

Regular expression matching URL: [a-zA-z]://[^s]*
Comment: The version circulating on the Internet has very limited functions. The above one can basically meet the needs

Is the matching account legal (starting with a letter, 5-16 bytes allowed, alphanumeric underscores allowed): ^[a-zA-Z][a-zA-Z0-9_]{4,15}$
Comment: Very useful for form validation

Match domestic phone numbers: d{3}-d{8}|d{4}-d{7}
Comment: Matching format such as 0511-4405222 or 021-87888822

Matches Tencent QQ number: [1-9][0-9]{4,}
Comment: Tencent QQ account starts from 10000

Match Chinese postal code: [1-9]d{5}(?!d)
Comment: China’s postal code is a 6-digit number

Matching ID card: d{15}|d{18}
Comment: China’s ID card has 15 or 18 digits

Match ip address: d .d .d .d
Comment: Useful when extracting IP address

Match specific numbers
[copy] ^[1-9]d*$  ​​// Match positive integers
^-[1-9]d*$ // Match negative integers
^-?[1-9]d*$  ​​//Match integers
^[1-9]d*|0$ // Match non-negative integers (positive integers 0)
^-[1-9]d*|0$  // Match non-positive integers (negative integers 0)
^[1-9]d*.d*|0.d*[1-9]d*$  ​​//Match positive floating point numbers
^-([1-9]d*.d*|0.d*[1-9]d*)$ //Match negative floating point numbers
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0 |0)$ // Match floating point number
^[1-9]d*.d*|0.d*[1-9]d*|0?.0 |0$  //Match non-negative floating point numbers (positive floating point numbers 0)
^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0 |0$  //Match non-positive floating point numbers (negative floating point numbers 0)

Comment: Useful when processing large amounts of data, please pay attention to corrections when applying specifically

Match specific string
[copy]^[A-Za-z] $ //Match a string consisting of 26 English letters
^[A-Z] $ // Matches a string consisting of 26 uppercase English letters
^[a-z] $ // Matches a string consisting of 26 lowercase English letters
^[A-Za-z0-9] $ // Matches a string consisting of numbers and 26 English letters
^w $  // Matches a string consisting of numbers, 26 English letters or underscores

Comments: Some of the most basic and commonly used expressions

Mind Map

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach是es6里的吗foreach是es6里的吗May 05, 2022 pm 05:59 PM

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.