>웹 프론트엔드 >JS 튜토리얼 >정규식의 특수 문자

정규식의 특수 문자

巴扎黑
巴扎黑원래의
2017-03-18 10:31:581709검색

1.JS 정규 표현식 모음( on )

정규 표현식의 특수 문자
문자 의미
는 의미의 변화로 사용됩니다. 즉, 일반적으로 "" 뒤의 문자는 원래 의미에 따라 해석되지 않습니다. /b/ 일치 문자 "b", /b/ 앞에 백슬래시가 있으면 단어 경계와 일치하도록 변경됩니다.
-또는-
정규식 함수 문자 복원(예: "*" 이전의 메타 문자와 0회 이상 일치, /a*/는 "" , /a를 추가한 후 a, aa, aaa와 일치) */는 "a*"에만 일치합니다.
^은 입력 또는 줄의 시작과 일치합니다. /^a/는 "an A"와 일치하지만 "An a"와는 일치하지 않습니다.
$는 입력 또는 줄의 끝과 일치합니다. /a$/ "An a"와 일치, "an A"와 일치하지 않음
* 이전 메타 문자와 0회 이상 일치, /ba*/는 b,ba,baa,baaa와 일치
+ 이전 메타 문자와 1회 이상 일치 번, / ba*/는 ba,baa,baaa와 일치합니다
? 앞의 메타 문자를 0 또는 1번 일치합니다. /ba*/는 b,ba와 일치합니다
(x) x 일치 $1이라는 파일에 x를 저장합니다. ... $9 변수에서
x|y는 x 또는 y와 일치합니다.
{n}은 정확히 n번 일치합니다.
{n,}는 n번 이상 일치합니다.
{n,m}은 일치합니다. n-m 번
[ xyz] 문자 집합, 이 집합의 모든 문자(또는 메타 문자)와 일치합니다.
[^xyz]는 이 집합의 어떤 문자와도 일치하지 않습니다.
[b]는 백스페이스 문자와 일치합니다.
b 단어 경계와 일치
B 단어가 아닌 경계와 일치
cX 여기서 X는 제어 문자, /cM/은 Ctrl-M과 일치
d 영숫자 문자와 일치, /d / = /[0- 9]/
D는 영숫자가 아닌 문자와 일치하고, /D/ = /[^0-9]/
n은 개행 문자와 일치합니다.
r은 캐리지 리턴 문자와 일치합니다.
s는 공백과 일치합니다. n, r, f, t, v 등을 포함한 문자.
S는 /[^nfrtv]/와 같은 공백이 아닌 문자와 일치합니다.
t는 탭 문자와 일치합니다.
v는 반복 탭과 일치합니다. 문자
w는 밑줄을 포함하여 단어를 구성할 수 있는 문자(영숫자, 숫자를 포함한 내 무료 번역)와 일치합니다. 예를 들어 [w]는 "$5.98"의 5와 일치하며 이는 [a- zA- Z0-9]
W는 단어를 구성할 수 없는 문자와 일치합니다. 예를 들어 [W]는 "$5.98"의 $와 일치하며 이는 [^a-zA-Z0-9]와 같습니다.

2.JS 정규표현식 모음(2부)
정규표현식은 문자 패턴을 기술하는 객체이다.
JavaScript의 RegExp 개체와 String 개체는 정규식을 사용하여 강력한 패턴 일치와 텍스트 검색 및 대체 기능을 수행하는 메서드를 정의합니다.
JavaScript에서 정규식은 RegExp 개체로 표현됩니다. RegExp() 생성자를 사용하여 RegExp 객체를 생성하거나 JavaScript 1.2에 새로 추가된 특수 구문을 사용하여 RegExp 객체를 생성할 수 있습니다. 문자열 리터럴이 따옴표로 묶인 문자로 정의되는 것과 마찬가지로 정규식 리터럴은 다음과 같이 정의됩니다. 문자는 슬래시(/) 쌍 사이에 포함됩니다. 따라서 JavaScript에는 다음 코드가 포함될 수 있습니다.
var 패턴 = /s$/
이 코드 줄은 새 RegExp 객체를 생성하고 이를 변수에 할당합니다. 이 특수 RegExp 개체는 문자 "s"로 끝나는 모든 문자열과 일치합니다. RegExp() 를 사용하여 동등한 정규식을 정의할 수도 있습니다. 코드는 다음과 같습니다.
var 패턴 = new RegExp("s$") ;
정규식 리터럴을 사용하든 RegExp() 생성자를 사용하든 RegExp 객체를 만드는 것은 상대적으로 쉽습니다. 정규식 구문을 사용하여 문자 패턴을 설명하는 것은 더 어렵습니다. Perl 언어 정규식 구문의 완전한 하위 집합을 사용합니다.
정규식의 패턴 사양은 일련의 문자로 구성됩니다. 대부분의 문자(모든 영숫자 문자 포함)는 문자 그대로 일치하는 문자를 설명합니다. 정규식 /java/는 하위 문자열 "java"를 포함하는 모든 문자열과 일치합니다. 정규식의 다른 문자는 문자 그대로 일치하지 않지만 모두 특수한 의미를 갖습니다.
첫 번째 특수 문자 "s"는 문자 그대로 일치합니다. 두 번째 문자 "$"는 문자열 끝과 일치하는 특수 문자입니다. 따라서 정규식 /s$/는 문자 "s"로 끝나는 문자열과 일치합니다. .

1. 리터럴 문자 JavaScript 정규 표현식은 백슬래시()로 시작하는 이스케이프 시퀀스도 사용합니다. 예를 들어, 시퀀스 "n"은 문자열의 리터럴 개행 문자와 일치합니다. 정규식에서 많은 구두점 문자는 특별한 의미를 갖습니다. 다음은 이러한 문자와 그 의미입니다.
정규식 리터럴 문자
문자 일치
______________
영숫자 문자 자체
f 양식 피드 문자
n 개행 문자
r 캐리지 리턴
t 탭
v 세로 탭
/ a/ 직접 수량
직접수량
. a. 리터럴
* a* 리터럴
? a ? 리터럴
| a | 리터럴
( a ( 리터럴
) a ) 리터럴 a [ 리터럴
] a ] 리터럴
{ a { 리터럴
} a } 리터럴
XXX 십진수로 지정된 ASCII 코드 문자 XXX
특수 구두점을 사용하려면 a를 추가해야 합니다.

2. 문자 클래스

문자 클래스를 구성하려면 개별 직접 문자를 넣으세요. A 문자 클래스는 포함된 모든 문자와 일치하므로 정규식 / [abc ] /는 문자 "a", "b" 및 "c" 중 하나와 일치합니다. 또한 부정 문자 클래스를 정의할 수 있습니다. 이러한 클래스는 부정 문자 팁을 정의할 때 대괄호로 묶인 문자를 제외한 모든 문자와 일치합니다. ^ 기호는 왼쪽 대괄호부터 계산하여 첫 번째 문자로 사용됩니다. 정규식 세트는 / [a-zA-z0-9] /
특정 문자 클래스가 매우 일반적으로 사용되기 때문에 JavaScript의 정규식 구문에는 다음이 포함됩니다. 이러한 일반적으로 사용되는 클래스를 나타내는 일부 특수 문자 및 이스케이프 시퀀스입니다. 예를 들어 s는 공백 문자, 탭 문자 및 기타 공백 문자이며 s는 공백 문자를 제외한 모든 문자와 일치합니다. 유형 문자 클래스
문자 일치 ______________________________________ [.. .] 괄호 안의 모든 문자
[^...] 괄호 안의 모든 문자
와 동일. [^n]
w [a-zA-Z0-9]에 해당하는 모든 단일 단어 문자
W [^a-zA-Z0-9]에 해당하는 단일 단어가 아닌 문자
s [t n r f v ]에 해당하는 모든 공백 문자
S [^ t n r f v]에 해당하는 공백이 아닌 모든 문자
d [0-9]에 해당하는 모든 숫자
D 다음을 제외한 모든 문자 숫자, [^0 -9]
[b] 백스페이스 리터럴(특수 사례)
______________________________________________________________

3. 복사

위의 정규식 구문을 사용하면 두 자리 숫자를 변환할 수 있습니다. /d d /로 설명되는 4자리 숫자는 /d d d d /로 설명됩니다. 그러나 숫자의 개수나 문자열을 설명하는 방법은 아직 없습니다. 이 문자열은 뒤에 오는 세 개의 문자로 구성됩니다. 문자는 한 자리 숫자로 구성됩니다. 이러한 복잡한 패턴에 사용되는 정규식 구문은 표현식의 각 요소가 반복되는 횟수를 지정합니다.
은 복사된 문자가 적용되는 패턴 뒤에 항상 표시되도록 지정합니다. 특정 복사 유형은 매우 일반적이므로 이를 나타내는 데 사용되는 특수 문자가 있습니다. 예: +는 이전 패턴을 한 번 이상 복사하는 패턴과 일치합니다. 먼저 복사 구문을 살펴보겠습니다. . :
/d{2, 4}/ //2와 4 사이의 숫자를 일치시킵니다.
/w{3} d?/ //단일 문자 3개와 임의의 숫자를 일치시킵니다. / s+ javas+/ //문자열 "java"와 일치하며 문자열 앞뒤에 공백이 하나 이상 있을 수 있습니다. /[^"] * / //따옴표가 아닌 문자를 0개 이상 일치합니다.

정규식 문자 복사

문자 의미
__________________________________________________________________________
{n, m}은 이전 항목과 최소 n회 일치하지만 m회 이하
{n, } 일치 이전 항목이 n번 또는 여러 번 {n}은 이전 항목과 정확히 n번 일치합니다. ? 이전 항목이 0 또는 1번 일치합니다. 이는 이전 항목이 선택 사항임을 의미합니다.
* 이전 항목과 0번 이상 일치합니다.
____________________________________________________________________________

4. 선택, 그룹화 및 인용

정규식 구문에는 특수 문자도 포함됩니다. 선택 항목을 지정하고, 하위 표현식을 그룹화하고, 이전 하위 표현식을 참조하기 위한 문자입니다. 예를 들어, /ab|cd|ef/는 문자열 "ab" 또는 " ef". /d{3}|[a-z]{4}/는 세 자리 숫자 또는 네 개의 소문자와 일치합니다. 표현식의 일반 괄호는 여러 가지 용도로 사용됩니다. 주요 목적은 개별 항목을 하위 표현식으로 그룹화하는 것입니다. 항목은 *, + 또는 ?를 사용하여 독립적인 단위인 것처럼 처리될 수 있습니다. 예: /java( script) ?/ 뒤에 "script"가 올 수도 있고 그렇지 않을 수도 있는 문자열 "java"와 일치합니다. ab|cd) + |ef) / 문자열 "ef"와 일치하거나 문자열 "ab" 또는 "cd"가 한 번 이상 반복됩니다.정규식에서 괄호를 사용하는 두 번째 방법은 전체 패턴 내에서 하위 패턴을 정의하는 것입니다. 정규 표현식이 대상 문자열과 성공적으로 일치하면 괄호 안의 하위 패턴과 일치하는 대상 문자열 부분을 추출할 수 있습니다. 예를 들어, 검색하는 패턴이 하나 이상의 문자 뒤에 단일 숫자 또는 여러 숫자가 있다고 가정합니다. , 그러면 /[a-z]+d+/ 패턴을 사용할 수 있습니다. 그러나 각 일치 항목의 끝 부분에 있는 숫자에 실제로 관심이 있다고 가정하므로 패턴의 숫자 부분을 괄호(/[a-z) 안에 넣습니다. ] + (d+)/) 검색된 일치 항목에서 숫자를 추출할 수 있으며, 이를 나중에 구문 분석할 것입니다.
괄호로 묶인 하위 표현식의 또 다른 용도는 다음을 수행하는 것입니다. 문자열 뒤에 하나 이상의 숫자를 추가하면 됩니다. 예를 들어 1은 첫 번째 대괄호의 하위 식을 나타냅니다. 하위 표현식은 다른 하위 표현식에 중첩될 수 있으므로 해당 위치는 왼쪽 괄호의 위치를 ​​계산하여 결정됩니다.
예: 다음 정규 표현식에서는 2로 지정됩니다.
/([Jj]ava([ Ss]cript)) sis s (funw*) /
pair 정규식의 이전 하위 표현식에 대한 참조는 해당 하위 표현식의 패턴을 지정하지 않지만, 이러한 방식으로 참조는 다음과 같습니다. 정규식의 반복되는 부분을 입력하는 데 도움이 되는 단축키일 뿐만 아니라 문자열의 각 부분이 정확히 동일한 문자를 포함하는 규칙도 구현합니다. 예를 들어 다음 정규식은 작은따옴표 안에 있는 모든 문자와 일치합니다. 또는 큰따옴표를 사용하려면 시작 및 끝 따옴표가 일치해야 합니다(예: 둘 다 큰 따옴표이거나 둘 다 작은 따옴표).
/[' "] [^ ' "]*[' "]/
시작 및 끝 따옴표가 필요한 경우 닫는 따옴표를 일치시키려면 다음 따옴표를 사용할 수 있습니다.
/( [' "] ) [^ ' "] * 1/
1은 일치하는 패턴과 일치합니다. 괄호의 첫 번째 하위 표현식으로. 이 예에서는 여는 따옴표가 닫는 따옴표와 일치해야 한다는 규칙을 적용합니다. 백슬래시 뒤에 괄호를 대체하는 하위 표현식의 수보다 많은 숫자가 오면 참조가 아닌 10진수 이스케이프 시퀀스로 구문 분석됩니다. 이스케이프 시퀀스를 나타내기 위해 전체 3개 문자를 사용하면 혼동을 피할 수 있습니다.b는 단어의 경계와 일치합니다. 즉, 문자 w와 w 사이의 위치입니다. (참고: [b]는 백스페이스 문자와 일치합니다.)
B는 단어가 아닌 경계 문자와 일치합니다.
_____________________________________________________
6. 속성
정규식의 문법에는 마지막 요소가 있는데, 이는 고급 패턴 일치의 규칙을 설명하는 정규식의 속성이며, 기타 정규식의 구문은 다릅니다. , 속성은 / 기호 외부에 지정됩니다. 즉, 두 개의 슬래시 사이에 나타나지 않지만 JavaScript 1.2는 두 개의 속성을 지원합니다. 속성 g는 대소문자를 구분하지 않음을 나타냅니다. 패턴 일치는 전역적이어야 합니다. 즉, 검색된 문자열에서 모든 일치 항목을 찾아야 합니다. 이 두 속성을 결합하여 대소문자를 구분하지 않는 전역 일치를 수행할 수 있습니다.
예: 크기를 구분하지 않는 작업을 수행합니다. "java"(또는 "java", "JAVA" 등)라는 단어의 첫 번째 특정 값을 찾기 위해 검색하면 크기를 구분하지 않는 정규 표현식 /b javab/i를 사용할 수 있습니다. 문자열에 "java" 값이 있는 경우 g 속성, 즉 /b java b/gi를 추가할 수도 있습니다.
JS 정규식 모음 [3]
다음은 정규식의 속성입니다. :
문자 의미
___________________________
i는 대소문자를 구분하지 않는 일치를 수행합니다.
g는 전역 일치를 수행합니다. 즉, 첫 번째 일치 항목을 찾은 후 중지하는 대신 모든 일치 항목을 찾습니다.
_______________________________________________
제외 속성 g 및 i의 경우 정규식에는 속성과 유사한 다른 특성이 없습니다. 생성자 RegExp Set의 정적 속성 multiline을 true로 설정하면 패턴 일치가 여러 줄 모드에서 수행됩니다. 문자 ^ 및 $는 검색 문자열의 시작과 끝과 일치할 뿐만 아니라 행 내의 검색 문자열과도 일치합니다. 예를 들어 /Java$/ 패턴은 "Java"와 일치하지만 "와는 일치하지 않습니다. Javanis fun". 여러 줄 속성을 설정하면 후자도 일치합니다:
RegExp.multiline = true ;
JAVASCRIPT에서 문자열이 이메일 형식인지 확인:

if(formname.email.value!=formname.email.value.match(/^\w +[@]\w +[.][\w.] +$/)) 
{ 
alert("您的电子邮件格式错误!"); 
formname.email.focus(); 
return false; 
} 
[RED]function dateVerify(date){ 
var reg = /^(\d{4})(-)(\d{2})\2(\d{2})$/; 
var r = date.match(reg); 
if(r==null) return false; 
var d= new Date(r[1], r[3]-1,r[4]); 
var newStr=d.getFullYear()+r[2]+(d.getMonth()+1)+r[2]+d.getDate(); 
date=r[1]+r[2]+((r[3]-1)+1)+r[2]+((r[4]-1)+1); 
return newStr==date; 
}

javascript的17种正则表达式 
"^\\d+$"  //非负整数(正整数 + 0) 
"^[0-9]*[1-9][0-9]*$"  //正整数 
"^((-\\d+)|(0+))$"  //非正整数(负整数 + 0) 
"^-[0-9]*[1-9][0-9]*$"  //负整数 
"^-?\\d+$"    //整数 
"^\\d+(\\.\\d+)?$"  //非负浮点数(正浮点数 + 0) 
"^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数 
"^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$"  //非正浮点数(负浮点数 + 0) 
"^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数 
"^(-?\\d+)(\\.\\d+)?$"  //浮点数 
"^[A-Za-z]+$"  //由26个英文字母组成的字符串 
"^[A-Z]+$"  //由26个英文字母的大写组成的字符串 
"^[a-z]+$"  //由26个英文字母的小写组成的字符串 
"^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串 
"^\\w+$"  //由数字、26个英文字母或者下划线组成的字符串 
"^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$"    //email地址 
"^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"  //url 
JavaScript中的正则表达式
正则表达式对象的属性及方法 
预定义的正则表达式拥有有以下静态属性:input, multiline, lastMatch, lastParen, leftContext, rightContext和$1到$9。其中input和multiline可以预设置。其他属性的值在执行过exec或test方法后被根据不同条件赋 以不同的值。许多属性同时拥有长和短(perl风格)的两个名字,并且,这两个名字指向同一个值。(JavaScript模拟perl的正则表达式) 
正则表达式对象的属性 
属性 含义 
$1...$9 如果它(们)存在,是匹配到的子串 
$_ 参见input 
$* 参见multiline 
$& 参见lastMatch 
$+ 参见lastParen 
$` 参见leftContext 
$''          参见rightContext 
constructor    创建一个对象的一个特殊的函数原型 
global       是否在整个串中匹配(bool型) 
ignoreCase     匹配时是否忽略大小写(bool型) 
input        被匹配的串 
lastIndex     最后一次匹配的索引 
lastParen     最后一个括号括起来的子串 
leftContext    最近一次匹配以左的子串 
multiline     是否进行多行匹配(bool型) 
prototype     允许附加属性给对象 
rightContext    最近一次匹配以右的子串 
source       正则表达式模式 
lastIndex     最后一次匹配的索引 
正则表达式对象的方法 
方法 含义 
compile      正则表达式比较 
exec        执行查找 
test        进行匹配 
toSource      返回特定对象的定义(literal representing),其值可用来创建一个新的对象。重载Object.toSource方法得到的。 
toString      返回特定对象的串。重载Object.toString方法得到的。 
valueOf      返回特定对象的原始值。重载Object.valueOf方法得到 
例子 
334f6305b6ca5b80c0fa1a5fd0526a69 
var myReg = /(w+)s(w+)/; 
var str = "John Smith"; 
var newstr = str.replace(myReg, "$2, $1"); 
document.write(newstr); 
2cacc6d41bbb37262a98f745aa00fbf0 
将输出"Smith, John" 
JS正则表达式大全 

/********************************************************************************* 
* EO_JSLib.js 
* javascript正则表达式检验 
**********************************************************************************/ 
//校验是否全由数字组成 
function isDigit(s) 
{ 
var patrn=/^[0-9]{1,20}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串 
function isRegisterUserName(s) 
{ 
var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验用户姓名:只能输入1-30个以字母开头的字串 
function isTrueName(s) 
{ 
var patrn=/^[a-zA-Z]{1,30}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验密码:只能输入6-20个字母、数字、下划线 
function isPasswd(s) 
{ 
var patrn=/^(\w){6,20}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-” 
function isTel(s) 
{ 
//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/; 
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验手机号码:必须以数字开头,除数字外,可含有“-” 
function isMobil(s) 
{ 
var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验邮政编码 
function isPostalCode(s) 
{ 
//var patrn=/^[a-zA-Z0-9]{3,12}$/; 
var patrn=/^[a-zA-Z0-9 ]{3,12}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
//校验搜索关键字 
function isSearch(s) 
{ 
var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;&#39;\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;&#39;\,.<>?]{0,19}$/; 
if (!patrn.exec(s)) return false 
return true 
} 
function isIP(s) //by zergling 
{ 
var patrn=/^[0-9.]{1,20}$/; 
if (!patrn.exec(s)) return false 
return true 
}

正则表达式regular expression详述
正则表达式是regular expression,看来英文比中文要好理解多了,就是检查表达式符 
不符合规定!!正则表达式有一个功能十分强大而又十分复杂的对象RegExp,在JavaScript1.2 版本以上提供。 
下面我们看看有关正则表达式的介绍: 
正则表达式对象用来规范一个规范的表达式(也就是表达式符不符合特定的要求,比如是不是Email地址格式等),它具有用来检查给出的字符串是否符合规则的属性和方法。 
除此之外,你用RegExp构造器建立的个别正则表达式对象的属性,就已经预先定义好了正则表达式对象的静态属性,你可以随时使用它们。 
核心对象: 
在JavaScript 1.2, NES 3.0以上版本提供。 
在JavaScript 1.3以后版本增加了toSource方法。 
建立方法: 
文字格式或RegExp构造器函数。 
文字建立格式使用以下格式: 
/pattern/flags即/模式/标记 
构造器函数方法使用方法如下: 
new RegExp("pattern"[, "flags"])即new RegExp("模式"[,"标记"]) 
参数: 
pattern(模式)  ——表示正则表达式的文本 
flags(标记) ——如果指定此项,flags可以是下面值之一: 
g: global match(全定匹配) 
i: ignore case(忽略大小写) 
gi: both global match and ignore case(匹配所有可能的值,也忽略大小写) 
注意:文本格式中的参数不要使用引号标记,而构造器函数的参数则要使用引号标记。所以下面的表达式建立同样的正则表达式: 
/ab+c/i 
new RegExp("ab+c", "i") 
描述:当使用构造函数的时候,必须使用正常的字符串避开规则(在字符串中加入前导字符\ )是必须的。 例如,下面的两条语句是等价的: 
re = new RegExp("\\w+") 
re = /\w+/ 
下面的提供了在正则表达式中能够使用的完整对特殊字符的一个完整的列表和描述。 
表1.3:正则表达式中的特殊字符: 
字符\ ——意义:对于字符,通常表示按字面意义,指出接着的字符为特殊字符,\不作解释。 
例如:/b/匹配字符'b',通过在b 前面加一个反斜杠\,也就是/\b/,则该字符变成特殊字符,表示 
匹配一个单词的分界线。 
或者: ——对于几个字符,通常说明是特殊的,指出紧接着的字符不是特殊的,而应该按字面解释。 
例如:*是一个特殊字符,匹配任意个字符(包括0个字符);例如:/a*/意味匹配0个或多个a。 
为了匹配字面上的*,在a前面加一个反斜杠;例如:/a\*/匹配'a*'。 
字符^ ——意义:表示匹配的字符必须在最前边。 
例如:/^A/不匹配"an A,"中的'A',但匹配"An A."中最前面的'A'。 
字符$ ——意义:与^类似,匹配最末的字符。 
例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。 
字符* ——意义:匹配*前面的字符0次或n次。 
例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不匹配"A goat g 
runted"中的任何字符。 
字符+ ——意义:匹配+号前面的字符1次或n次。等价于{1,}。 
例如:/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。 
字符? ——意义:匹配?前面的字符0次或1次。 
例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。 
字符. ——意义:(小数点)匹配除换行符外的所有单个的字符。 
例如:/.n/匹配"nay, an apple is on the tree"中的'an'和'on',但不匹配'nay'。 
字符(x) ——意义:匹配'x'并记录匹配的值。 
例如:/(foo)/匹配和记录"foo bar."中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返 
回,或被RegExp对象的属性$1, ..., $9返回。 
字符x|y ——意义:匹配'x'或者'y'。 
例如:/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。 
字符{n} ——意义:这里的n是一个正整数。匹配前面的n个字符。 
예를 들어, /a{2}/는 "candy"의 'a'와 일치하지 않지만 "caandy"의 모든 'a' 및 "caaandy."의 처음 두
'a와 일치합니다.
문자 {n,} - 의미: 여기서 n은 양의 정수입니다. 최소한 n개의 이전 문자와 일치합니다.
예: /a{2,}는 "candy"의 'a'와 일치하지 않지만 "caandy"의 모든 'a' 및 "caaaaaaandy"의 모든 'a'와 일치합니다.
문자 {n ,m} - 의미: 여기서 n과 m은 모두 양의 정수입니다. 최소 n개, 최대 m개의 이전 문자와 일치합니다.
예: /a{1,3}/는 "cndy"의 어떤 문자와도 일치하지 않지만 "candy"의 'a' 및 "caandy"의 처음 두
'a'와 일치합니다. 그리고 "caaaaaaandy"의 처음 세 개의 'a', 참고: "caaaaaaandy"에 'a'가 많더라도 처음 세 개의
'a, 즉 "aaa"만 일치합니다.
문자[xyz]——의미: 목록의 모든 문자와 일치하는 문자 목록입니다. 하이픈 -을 사용하여 문자 범위를 지정할 수 있습니다.
예: [abcd]는 [a-c]와 동일합니다. 이는 "brisket"의 'b'와 "ache"의 'c'와 일치합니다.
문자[^xyz]——의미: 한 문자 보완, 즉 나열된 문자를 제외한 모든 문자와 일치합니다. 하이픈을 사용하여 문자 범위를 나타낼 수 있습니다.
예: [^abc]와 [^a-c]는 동일합니다. 먼저 "brisket"의 'r'과 "chop."의 'h'와 일치합니다.
문자 [b]——의미: 공백과 일치(b와 혼동하지 마세요)
문자 b——의미: 공백과 같은 단어의 구분선과 일치([와 혼동하지 마십시오) b])
예를 들어 /bnw/는 "noonday"의 'no'와 일치하고, /wyb/는 "아마도 어제"의 'ly'와 일치합니다.
문자 B - 의미: 단어의 줄바꿈 ​​없는 줄과 일치합니다.
예: /wBn/은 "noonday"의 'on'과 일치하고, /yBw/는 "possously Tuesday"의 'ye'와 일치합니다. .
문자 cX - 의미: 여기서 X는 제어 문자입니다. 제어 문자 문자열과 일치합니다.
예를 들어 /cM/은 문자열의 control-M과 일치합니다.
문자 d - 의미: 숫자와 일치하며 [0-9]에 해당합니다.
예를 들어 /d/ 또는 /[0-9]/는 "B2가 모음 번호입니다."의 '2'와 일치합니다.
문자 D - 의미: 숫자가 아닌 모든 것과 일치하며 [^0-9]와 같습니다.
예를 들어 /D/ 또는 /[^0-9]/는 "B2가 모음 번호입니다."의 'B'와 일치합니다.
문자 f——의미: 형식 문자 일치
문자 n——의미: 개행 문자 일치
문자 r——의미: 캐리지 리턴 문자 일치
문자 s——의미: 일치 공백, 탭, 폼 피드, 개행 문자를 포함한 단일 공백 ​​문자는 [fnrtv]와 동일합니다.
예를 들어 /sw*/는 "foo bar"의 'bar'와 일치합니다.
문자 S - 의미: 공백을 제외한 단일 문자와 일치하며 [^ fnrtv]와 동일합니다.
예: /S/w*는 "foo bar"의 'foo'와 일치합니다.
문자 t - 의미: 탭 문자 일치
문자 v - 의미: 선행 탭 문자 일치
문자 w - 의미: 모든 숫자, 문자 및 밑줄 일치([A-Za-z0-와 동일) 9_].
예를 들어 /w/는 'apple'의 'a', '$5.28'의 '5', '3D'의 '3'과 일치합니다.
문자 W - 의미: 숫자, 문자, 밑줄을 제외한 다른 문자와 일치하며 [^A-Za-z0-9_]와 동일합니다.
예를 들어 /W/ 또는 /[^$A-Za-z0-9_]/는 "50%"의 '%'와 일치합니다.
문자 n——의미: n은 양의 정수입니다. 정규식의 마지막 하위 문자열과 일치하는 n 값(왼쪽 괄호 수 계산)
예: /apple(,)sorange1/은 "사과, 오렌지, 체리, 복숭아"의 '사과, 오렌지'와 일치합니다. 아래에 더 완전한 예가 있습니다
.
참고: 왼쪽 괄호 안의 숫자가 n으로 지정된 숫자보다 작은 경우 n은 다음 줄의 8진수 이스케이프를 설명으로 사용합니다.
문자 ooctal 및 xhex - 의미: 여기서 ooctal은 8진수 이스케이프 값이고 xhex는 16진수 이스케이프 값으로, ASCII 코드를 정규 표현식에 포함할 수 있습니다.
리터럴 표기법은 표현식을 확인할 때 정규 표현식을 편집하는 방법을 제공합니다. 리터럴 표기법을 사용하여 정규식을 일정하게 유지할 수 있습니다. 예를 들어 루프에서 리터럴 표기법을 사용하여 정규식을 생성하는 경우 정규식을 반복적으로 컴파일할 필요가 없습니다.
正则表达式对象构造器,例如,new RegExp("ab+c"),提供正则表达式的运行时编译。当你知道正 则表达式的模式会变化的时候,应该使用构造函数,或者你不知道正则表达式的模式,而它们是从另外 的源获得的时候,比如由用户输入时。一旦你定义好了正则表达式,该正则表达式可在任何地方使用, 并且可以改变,你可以使用编译方法来编译一个新的正则表达式以便重新使用。 
一个分离预先定义的RegExp对象可以在每个窗口中使用;也就是说,每个分离的JavaScript线程运 行以获得自己的RegExp对象。因为每个脚本在一个线程中是不可中断的,这就确保了不同的脚本不会覆 盖RegExp对象的值。 
预定义的RegExp对象包含的静态属性:input, multiline, lastMatch,lastParen, leftContext, rightContext, 以及从$1到$9。input和multiline属性能被预设。其它静态属性的值是在执行个别正则 表达式对象的exec和test方法后,且在执行字符串的match和replace方法后设置的。 
属性 
注意RegExp对象的几个属性既有长名字又有短名字(象Perl)。这些名字都是指向相同的值。Perl是 一种编程语言,而JavaScript模仿了它的正则表达式。 
属性$1, ..., $9 
取得匹配的子串,如果有的话 
属性$_ 
参考input 
属性$* 
参考multiline 
属性$& 
参考lastMatch 
属性$+ 
参考lastParen 
属性$` 
参考leftContext 
属性$' 
参考rightContext 
属性constructor 
指定用来建立对象原型函 
属性global 
决定是否测试正则表达式是否不能匹配所有的字符串,或者只是与最先的冲突。 
属性ignoreCase 
决定试图匹配字符串的时候是否忽略大小写 
属性input 
当正则表达式被匹配的时候,为相反的字符串。 
属性lastIndex 
决定下一次匹配从那里开始 
属性lastMatch 
最后一个匹配的字符 
属性lastParen 
子串匹配的时候,最后一个parenthesized,如果有的话。 
属性leftContext 
最近一次匹配前的子串。 
属性multiline 
是否在串的多行中搜索。 
属性prototype 
允许附加属性到所有的对象 
属性rightContext 
最近一次匹配后的的子串。 
属性source 
模式文本 

方法 
compile方法 
编译一个正则表达式对象 
exec方法 
运行正则表达式匹配 
test方法 
测试正则达式匹配 
toSource方法 
返回一个对象的文字描述指定的对象;你可以使用这个值来建立一个新的对象。不考虑Object.toS 
ource方法。 
toString方法 
返回一个字符串描述指定的对象,不考虑Object.toString对象。 
valueOf方法 
返回指定对角的原始值。不考虑Object.valueOf方法。 
 另外,这个对象继承了对象的watch和unwatch方法 

例子: 
例1、下述示例脚本使用replace方法来转换串中的单词。在替换的文本中,脚本使用全局 RegExp 
对象的$1和$2属性的值。注意,在作为第二个参数传递给replace方法的时候,RegExp对象的$属性的名 
称。 

<SCRIPT LANGUAGE="JavaScript1.2"> 
re = /(\w+)\s(\w+)/; 
str = "John Smith"; 
newstr=str.replace(re,"$2, $1"); 
document.write(newstr) 
</SCRIPT>

显示结果:"Smith, John". 
例2、下述示例脚本中,RegExp.input由Change事件处理句柄设置。在getInfo函数中,exec 方法 
使用RegExp.input的值作为它的参数,注意RegExp预置了$属性。 

<SCRIPT LANGUAGE="JavaScript1.2"> 
function getInfo(abc) 
{ 
re = /(\w+)\s(\d+)/; 
re.exec(abc.value); 
window.alert(RegExp.$1 + ", your age is " + RegExp.$2); 
} 
</SCRIPT> 
  请输入你的姓和年龄,输入完后按回车键。 
<FORM><INPUT TYPE="TEXT" NAME="NameAge" onChange="getInfo(this);"></FORM> 
</HTML>

$1, ..., $9属性 
用圆括号括着的匹配子串,如果有的话。 
是RegExp的属性 
静态,只读 
在JavaScript 1.2, NES 3.0以上版本提供 
描述:因为input是静态属性,不是个别正则表达式对象的属性。你可以使用RegExp.input 访问该 
属性。 
能加上圆括号的子串的数量不受限制,但正则表达式对象只能保留最后9 条。如果你要访问所有的 
圆括号内的匹配字串,你可以使用返回的数组。 
这些属性能用在RegExp.replace方法替换后的字符串(输出结果)。当使用这种方式的时候,不用预 
先考虑RegExp对象。下面给出例子。当正则表达式中没有包含圆括号的时候,该脚本解释成$n的字面意 
义。(这里的n是一个正整数)。 
例如: 
下例脚本使用replace 方法来交换串中单词的位置。在替换后的文本字串中,脚本使用正则表达式 
RegExp对象的$1和$2属性的值。注意:当它们向replace方法传递参数的时候,这里没有考虑 $ 属性的 
RegExp对象的名称。 

<SCRIPT LANGUAGE="JavaScript1.2"> 
re = /(\w+)\s(\w+)/; 
str = "John Smith"; 
newstr=str.replace(re,"$2, $1"); 
document.write(newstr) 
</SCRIPT>

显示的输出结果为:Smith, John。 
JS正则表达式大全 
正则表达式regular expression详述
以下这些不是正则表达式的新增对象请参阅对应的JavaScript对象的属性 $_属性 参考input $*属性 
参考multiline $&属性 参考lastMatch $+属性 参考lastParen $`属性 
参考leftContext $'属性 参考rightContext compile方法 在脚本运行期间编译正则表达式对象 
属于RegExp的方法 在JavaScript 1.2, NES 3.0以上版本提供 语法: 
regexp.compile(pattern[, flags]) 以数: regexp 正则表达式的名称,可以是变量名或文字串。 
pattern 正则表达式的定义文本。 flags 如果指定的话,可以是下面其中的一个: "g": 匹配所有可能的字串 
"i": 忽略大小写 "gi": 匹配所有可能的字串及忽略大小写 描述: 
使用compile方法来编译一个正则表达式 created with the RegExp constructor function。这样 
就强制正则表达式只编译一次,而不是每次遇到正则表达式的时候都编译一次。当你确认正则表达式能 
保持不变的时候可使用compile 方法来编译它(在获得它的匹配模式后),这样就可以在脚本中重复多次使用它。 
你亦可以使用compile 方法来改变在运行期间改变正则表达式。例如,假如正则表达式发生变化, 
你可以使用compile方法来重新编译该对象来提高使用效率。 
使用该方法将改变正则表达式的source, global和ignoreCasesource属性的值。 constructor 
指出建立对象原型的function。注意这个属性的值由函数本身提供,而不是一个字串包含RegExp的name.Property提供。 
在JavaScript 1.1, NES 2.0以上版本提供 ECMA版本ECMA-262 描述:参考Object.constructor. 
exec方法 在指定的字符串运行匹配搜索。返回一个结果数组。 是RegExp的方法 
在JavaScript 1.2, NES 3.0以上版本提供 语法: regexp.exec([str])regexp([str]) 
参数: regexp,正则表达式的名称,可以是一个变量名或文字定义串。 
str,要匹配正则表达式的字符串,如果省略,将使用RegExp.input的值。 
描述:就如在语法描述中的一样,正则表达工的exec方法能够被直接调用(使用regexp.exec(str))或者间接调用(使用regexp(str))。 
假如你只是运行以找出是否匹配,可以使用String搜索方法。 
假如匹配成功,exec方法返回一个数组并且更新正则表达式对象属性的值和预先定义的正则表达式对象、RegExp。如果匹配失败,exec方法返回null。 
请看下例: 8cc9a834f4278df216fc1f34199a18d6 //匹配一个b接着一个或多个d,再接着一个b 
//忽略大小写 myRe=/d(b+)(d)/ig; myArray = myRe.exec("cdbBdbsbz"); 
db271416853c42fd247a57c1a2c29eb6 下面是该脚本的返回值:对象 属性/Index 描述 例子 
myArray 
myArray的内容 ["dbBd", "bB", "d"] 
index 
基于0的匹配index 1 
input 
原始字符串 cdbBdbsbz 
[0] 
最后匹配的字符 dbBd 
[1], ...[n] 
用圆括号括住的匹配字符串,如果有的话。不限制括号的个数。 [1] = bB 
[2] = d 
myRe 
lastIndex 
开始下次匹配操作的index值 5 
ignoreCase 
指出"i"是否使用以忽略大小写 true 
global 
指出是否使用"g"标记来进行匹配所有可能的字串 true 
source 
定义模式的文本字符串 d(b+)(d) 
RegExp 
lastMatch$& 
最后匹配的字符 dbBd 
leftContext$\Q 
最新匹配前面的子串 c 
rightContext$' 
最新匹配后面的子串 bsbz 
$1, ...$9 
圆括号内的匹配子串,如果有的话。圆括号的个数不受限制,但RegExp只能保留最后9个 $1 = bB 
$2 = d 
lastParen $+ 
最后一个加上圆括号的匹配子串,如果有的话 d 
假如你的正则表达式使用了"g"标记,你可以多次使用exec 方法来连续匹配相同的串。当你这样做 
的时候,新的匹配将从由正则表达式的lastIndex 属性值确定的子串中开始。例如,假定你使用下面的脚本: 
8cc9a834f4278df216fc1f34199a18d6 myRe=/ab*/g;str = "abbcdefabh" 
myArray = myRe.exec(str); 
document.writeln("Found "+myArray[0]+". Next match starts at "+myRe.lastIndex) 
mySecondArray = myRe.exec(str);
document.writeln("Found "+mySecondArray[0]+". 다음 일치 항목은 "+myRe.lastIndex에서 시작됩니다.)
db271416853c42fd247a57c1a2c29eb6 결과 : abb를 찾았습니다. 다음 일치는 3에서 시작합니다.
찾은 ab. 다음 일치는 9에서 시작합니다. 예:
다음 예에서는 사용자가 이름을 입력하고 스크립트는 입력을 기반으로 일치 작업을 수행합니다. 그런 다음 배열이 다른 사용자의 이름과 일치하는지 확인합니다.
이 스크립트는 등록된 사용자의 성이 배열 A에 저장되었거나 데이터베이스에서 가져온 것으로 가정합니다. 6a74014ee44f5deb5894267f99b68016
50950bf35e67c33484f0159171ae2eae A = ["zhao","qian","sun","li","liang"]
함수 조회() { firstName = /w+/i(); if (!firstName)
window.alert (RegExp.input + "불법 입력") else { count=0;i 632555444b46edf0af44e58213a0ac8c6d0ed6c2a76bf254c5cafd3877ac0c6467c47c2f4e2e39e829bbcfb43fc3cadb
6eac519e8537e4205ddd37e30a7b548a 전역 속성 정규식에 사용됨, 읽기 전용
JavaScript 1.2, NES 3.0 이상에서 제공되는 설명: 전역은 개별 정규식 개체의 속성입니다.
"g" 태그를 사용하는 경우 전역 값은 다음과 같습니다. 그렇지 않으면 "g" 태그는 정규식이 가능한 모든 일치 항목을 테스트하도록 지정합니다.
이 속성의 값을 직접 변경할 수는 없지만, 정규식이 사용하는지 확인하기 위해 컴파일 메서드를 호출할 수 있습니다. "i" 태그
RegExp 속성은 JavaScript 1.2, NES 3.0 이상에서 읽기 전용입니다. 설명:
ignoreCase는 "i" 플래그가 사용된 경우
개별 정규 표현식 객체의 속성입니다. 지정하면 true를 반환하고, 그렇지 않으면 false를 반환합니다. "i" 플래그는 일치 시 대소문자가 무시됨을 나타냅니다.
이 속성의 값은 직접 변경할 수 없지만 컴파일 메서드 입력을 호출하여 변경할 수 있음을 나타냅니다. 정규식이 테스트해야 하는 문자열입니다. $_는 이 속성의 또 다른 이름입니다.
RegExp의 속성은 JavaScript 1.2, NES 3.0 이상에서 정적으로 사용할 수 있습니다.
설명: 입력은 정적이므로 개별 속성이 아닙니다. 정규식 개체를 사용하여 나타낼 수도 있습니다.
정규식의 exec 또는 테스트 메서드에 문자열이 제공되지 않고 RegExp.input에 값이 있으면 해당 값을 사용하여 호출합니다.
스크립트나 브라우저에서 입력 속성을 미리 설정할 수 있습니다. 값이 미리 설정되어 있고 exec 또는 테스트 메서드를 호출할 때 문자열이 제공되지 않으면 exec 또는 테스트 값을 호출할 때
가 사용됩니다. 입력은 다음과 같은 방법으로 브라우저에서 설정할 수 있습니다.
텍스트 양식 필드 핸들러가 호출되면 입력은 텍스트가 입력한 문자열로 설정됩니다.
텍스트 영역 양식 필드 핸들러가 호출되면 입력은 텍스트 영역 필드에 입력된 문자열로 설정됩니다. 여러 줄의 텍스트와 일치하도록 multili
ne도 true로 설정되어 있습니다. 선택 양식 필드 핸들러가 호출되면 입력은 선택한 텍스트의 값으로 설정됩니다.
링크 개체의 핸들러가 호출되면 입력은 6a2b3936541eb5c40626a82687b7bf27와 63505a6f727f70c8bd4066f3066dcb9d 사이의 문자열로 설정됩니다.
이벤트 핸들러가 처리된 후 입력 속성의 값이 지워집니다. lastIndex 다음 일치 항목이 시작되어야 하는 위치를 나타내는 읽기/쓰기 정수 속성입니다.
RegExp의 속성은 JavaScript 1.2, NES 3.0 이상에서 사용할 수 있습니다.
설명: lastIndex는 개별 정규식 개체의 속성입니다. 이 속성은 정규식의 "g" 플래그가 전체 문자열 일치에 사용되는 경우에만 설정됩니다. 다음 규칙이 적용됩니다.
lastIndex가 문자열 길이인 경우 regexp.test 및 regexp.exec는 실패하고 lastIndex는 0으로 설정됩니다.
lastIndex가 문자열 길이와 같고 정규식이 빈 문자열과 일치하는 경우 정규식은 lastIndex 위치부터 일치를 시작합니다.
lastIndex가 문자열 길이와 같고 정규식이 빈 문자열과 일치하지 않으면 정규식이 입력과 일치하지 않고 lastIndex가 0으로 설정됩니다.
그렇지 않으면 lastIndex가 가장 최근 일치 항목의 다음 지점으로 설정됩니다. 예를 들어 다음 순서로 스크립트를 실행합니다. re = /(hi)?/g는 빈 문자열과 일치합니다.
re("hi")는 ["hi", "hi"]를 반환하고 lastIndex를 2 re("hi")는 인덱스 0의 요소가 일치하는 문자열인 빈 배열인 [""]를 반환합니다. 이 경우 lastIndex가 2이고(여전히 2임) "hi"의 길이도 2이기 때문에 빈
문자열이 반환됩니다. lastMatch는 마지막 문자열과 일치하며 $&는 동일한 의미를 갖습니다.
RegExp 속성, 정적, 읽기 전용 JavaScript 1.2, NES 3.0 이상에서 사용 가능
설명: lastMatch는 정적이므로 개별 정규식을 지정하는 속성이 아닙니다. RegExp.lastMatch를 사용할 수도 있습니다. 라스트파렌
마지막 대괄호로 묶인 문자열이 일치합니다(있는 경우). $+도 같은 의미입니다. RegExp 속성, 정적, 읽기 전용
JavaScript 1.2, NES 3.0 이상에서 사용 가능
설명: lastParen은 정적이므로 개별 정규식의 속성이 아닙니다. RegExp.lastParen을 사용하여 표현할 수 있습니다. 같은 의미 .
leftContext는 가장 최근에 이전 하위 문자열과 일치했으며 $`는 동일한 의미를 갖습니다. RegExp 속성, 정적, 읽기 전용
JavaScript 1.2, NES 3.0 이상에서 사용 가능
설명: leftContext는 정적이고 정규 표현식의 속성이 아니기 때문에 RegExp.leftContext를 사용하여 동일한 의미를 표현할 수 있습니다.
multiline은 여러 줄의 텍스트를 일치시킬지 여부를 반영하며 $*는 동일한 의미를 갖습니다. RegExp의 속성, 정적
JavaScript 1.2, NES 3.0 이상에서 사용 가능
설명: multiline은 개별 정규식의 속성이 아니라 정적이기 때문에 RegExp.multiline을 사용하여 동일한 의미를 표현할 수 있습니다.
multiline은 여러 줄의 텍스트 일치가 허용되는 경우 true이고, 검색이 줄 바꿈에서 중지되어야 하는 경우 false입니다.
스크립트나 브라우저는 여러 줄 속성을 설정할 수 있습니다. 텍스트 영역 이벤트 핸들러가 호출되면 여러 줄
이 true로 설정됩니다. 이벤트 핸들러가 처리된 후 여러 줄 속성 값이 지워집니다. 즉, multiline
ne을 true로 설정하면 이벤트 핸들러를 실행한 후 multiline이 false로 설정됩니다. 프로토타입
은 클래스의 프로토타입을 설명합니다. 프로토타입을 사용하여 요구 사항에 따라 클래스의 속성이나 메서드를 추가할 수 있습니다. 프로토타입 정보를 얻으려면 RegExp의 Function.prototype.Property 속성을 참조하세요. JavaScript 1.1, NES 2.0 버전에서 사용 가능
ECMA 버전 ECMA-262 rightContext 오른쪽의 마지막 일치 문자열인 $'는 동일한 효과를 갖습니다.
정적, 읽기 전용 RegExp 속성은 JavaScript 1.2, NES 3.0 이상에서 사용할 수 있습니다.
설명: rightContext는 정적이고 개별 정규식 작업자의 속성이 아니기 때문에 RegExp.rightContext를 사용할 수 있습니다. 동일한 효과를 얻으려면.
source 슬래시 및 "g" 또는 "i" 태그를 제외하고 정규식으로 정의된 패턴을 포함하는 읽기 전용 속성입니다. RegExp의 속성, 읽기 전용
JavaScript 1.2, NES 3.0 이상에서 사용 가능
설명: 소스는 개별 정규 표현식 개체의 속성으로 해당 값을 직접 변경할 수는 없지만 다음을 호출하여 변경할 수 있습니다. 방법을 컴파일합니다. test
지정된 문자열에 대해 정규식 일치 검색을 수행하고 true 또는 false를 반환합니다. RegExp 방법
구문은 JavaScript 1.2, NES 3.0 이상부터 제공됩니다: regexp.test([str])
매개변수: regexp, 정규 표현식의 이름. 변수 이름 또는 정규 표현식일 수 있습니다. 표현식 정의 텍스트 문자열
str, 일치시킬 문자열입니다. 생략하면 RegExp.input의 값이 매개변수로 사용됩니다.
설명: 문자열이 특정 정규식과 일치할 수 있는지 알고 싶을 때. , 테스트 메서드( String.search 메서드
메서드와 유사)를 사용할 수 있습니다. 더 많은 정보를 얻으려면(그러나 속도는 느려집니다) exec 메서드(String.match 메서드와 유사)를 사용할 수 있습니다. ). 예: 다음 예는 테스트 성공 여부를 보여줍니다.
function testinput(re, str){
if (re.test(str)) midring = " contain "
else midring = " does not contain ";
document.write (str + midring + re.source); } toSource
객체를 상징하는 문자열의 소스 코드를 반환합니다. RegExp 메서드는 JavaScript 1.3 이상의 구문을 제공합니다: toSource()
매개변수: 설명 없음: toSource 메서드는 다음 값을 반환합니다. 내장 RegExp 개체의 경우 toSource는 소스 코드를 사용할 수 없음을 나타내기 위해 다음 문자를 반환합니다.
function Boolean(){ [네이티브 코드] }
RegExp의 경우 toSource는 소스 코드를 나타내는 문자열을 반환합니다. 일반적으로 이 메서드는 코드에서 명시적으로 호출되지 않고 JavaScript에 의해 내부적으로 자동 호출됩니다.
자세한 내용은 Object.toSource toString이 지정된 개체를 설명하는 문자열을 반환함을 참조하세요. RegExp의 메소드
ECMA 버전 ECMA-262는 JavaScript 1.1, NES 2.0부터 제공됩니다. 구문: toString() 매개변수: None
설명: RegExp 객체는 Object 객체의 toString 메소드를 고려하지 않습니다. .toString, RegExp
객체의 경우 toString 메서드는 객체를 나타내는 문자열을 반환합니다. 예: 다음 예에서는 RegExp 객체를 나타내는 문자열을 표시합니다.
myExp = new RegExp("a+b+c") Alert(myExp.toString())
displays "/a+b+c/ " 자세히 보기: Object.toString valueOf는 RegExp 객체의 원래 값을 반환합니다.
RegExp 메서드는 JavaScript 버전 1.1부터 사용할 수 있습니다. ECMA 버전: ECMA-262 구문: valueOf()
매개 변수: 없음 설명: RegExp의 valueOf 이 메소드는 RegExp.toString과 동일한 RegExp 개체의 원래 값을 문자열 형식으로 반환합니다.
이 메서드는 일반적으로 명시적으로 호출되지 않고 JavaScript 내에서 자동으로 호출됩니다. 예: myExp = new RegExp("a+b+c")
alert(myExp.valueOf())는 "/a+b+ c를 표시합니다. /"
JS正则表达式大全 
正则表达式在javascript中的几个实例1
! 去除字符串两端空格的处理 

如果采用传统的方式,就要可能就要采用下面的方式了 

//清除左边空格 
function js_ltrim(deststr) 
{ 
if(deststr==null)return ""; 
var pos=0; 
var retStr=new String(deststr); 
if (retStr.lenght==0) return retStr; 
while (retStr.substring(pos,pos+1)==" ") pos++; 
retStr=retStr.substring(pos); 
return(retStr); 
} 
//清除右边空格 
function js_rtrim(deststr) 
{ 
if(deststr==null)return ""; 
var retStr=new String(deststr); 
var pos=retStr.length; 
if (pos==0) return retStr; 
while (pos && retStr.substring(pos-1,pos)==" " ) pos--; 
retStr=retStr.substring(0,pos); 
return(retStr); 
} 
//清除左边和右边空格 
function js_trim(deststr) 
{ 
if(deststr==null)return ""; 
var retStr=new String(deststr); 
var pos=retStr.length; 
if (pos==0) return retStr; 
retStr=js_ltrim(retStr); 
retStr=js_rtrim(retStr); 
return retStr; 
}

采用正则表达式,来去除两边的空格,只需以下代码 

String.prototype.trim = function() 
{ 
return this.replace(/(^\s*)|(\s*$)/g, ""); 
}

一句就搞定了, 
可见正则表达式为我们节省了相当的编写代码量 

! 移动手机号的校验 
如果采用传统的校验方式至少就要完成下面三步的校验, 
(1). 是否是数字 
(2).是否是11位 
(3).数字的第三位是否是5,6,7,8,9 
如果采用正则表达式校验,只需以下代码 

function checkMobile1(form) 
{ 
if (form.mobile.value > "") 
{ 
var reg=/13[5,6,7,8,9]\d{8}/; 
if ( form.mobile.value.match(reg)== null) 
{ 
alert("请输入正确的移动手机号码!"); 
form.mobile.focus(); return false; 
} 
} 
return true; 
}

从上面的代码可以看出校验移动手机号只需定义一个var reg=/13[5,6,7,8,9]\d{8}/;模式匹配串就可以完成合法性校验了 
! URL的校验, 
条件:必须以http:// 或 https:// 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验 

//obj:数据对象 
//dispStr :失败提示内容显示字符串 
function checkUrlValid( obj, dispStr) 
{ 
if(obj == null) 
{ 
alert("传入对象为空"); 
return false; 
} 
var str = obj.value; 
var urlpatern0 = /^https?:\/\/.+$/i; 
if(!urlpatern0.test(str)) 
{ 
alert(dispStr+"不合法:必须以&#39;http:\/\/&#39;或&#39;https:\/\/&#39;开头!"); 
obj.focus(); 
return false; 
} 
var urlpatern2= /^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?.+$/i; 
if(!urlpatern2.test(str)) 
{ 
alert(dispStr+"端口号必须为数字且应在1-65535之间!"); 
obj.focus(); 
return false; 
} 
var urlpatern1 =/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i; 
if(!urlpatern1.test(str)) 
{ 
alert(dispStr+"不合法,请检查!"); 
obj.focus(); 
return false; 
} 
var s = "0"; 
var t =0; 
var re = new RegExp(":\\d+","ig"); 
while((arr = re.exec(str))!=null) 
{ 
s = str.substring(RegExp.index+1,RegExp.lastIndex); 
if(s.substring(0,1)=="0") 
{ 
alert(dispStr+"端口号不能以0开头!"); 
obj.focus(); 
return false; 
} 
t = parseInt(s); 
if(t<1 || t >65535) 
{ 
alert(dispStr+"端口号必须为数字且应在1-65535之间!"); 
obj.focus(); 
return false; 
} 
} 
return true; 
}

对 url的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1 =/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i; 一句就可以校验出url合法性了 
正则表达式在JavaScript应用 
-------------------------------------------------------------- 
去掉字符串头尾多余的空格 
/g是全文查找所有匹配 

function String.prototype.Trim(){return this.replace(/(^\s*)|(\s*$)/g, "");} 
function String.prototype.LTrim(){return this.replace(/(^\s*)/g, "");} 
function String.prototype.RTrim(){return this.replace(/(\s*$)/g, "");}

-------------------------------------------------------------- 
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 

String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}

-------------------------------------------------------------- 
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下: 

String.prototype.trim = function() 
{ 
return this.replace(/(^\s*)|(\s*$)/g, ""); 
}

得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1 

s="http://www.php.cn" 
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2") 
alert(s)

##利用正则表达式限制网页表单里的文本框输入内容: 
-------------------------------------------------------------- 
用 正则表达式限制只能输入中文:

onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,&#39;)" onbeforepaste="clipboardData.setData(&#39;text&#39;,clipboardData.getData(&#39;text&#39;).replace(/[^\u4E00-\u9FA5]/g,&#39;))"

-------------------------------------------------------------- 
用 正则表达式限制只能输入全角字符: 

onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,&#39;)" onbeforepaste="clipboardData.setData(&#39;text&#39;,clipboardData.getData(&#39;text&#39;).replace(/[^\uFF00-\uFFFF]/g,&#39;))"

-------------------------------------------------------------- 
用 正则表达式限制只能输入数字:

onkeyup="value=value.replace(/[^\d]/g,&#39;) "
onbeforepaste="clipboardData.setData(&#39;text&#39;,clipboardData.getData(&#39;text&#39;).replace(/[^\d]/g,&#39;))"

-------------------------------------------------------------- 
用 正则表达式限制只能输入数字和英文:

onkeyup="value=value.replace(/[\W]/g,&#39;) "
onbeforepaste="clipboardData.setData(&#39;text&#39;,clipboardData.getData(&#39;text&#39;).replace(/[^\d]/g,&#39;))"


用正则表达式和javascript对表单进行全面验证 
代码:8108cbe1d58f0ab0b8a10168eac341c1f5a47148e367a6035fd7a2faa965022e 
将对表单中的所有以下类型的域依次验证,所有验证是去除了前导和后缀空格的,要注意是区分大小写的。 
2、空值验证 
表单中任意域加上emptyInfo属性将对此域是否为空进行验证(可以和最大长度验证\一般验证方式同时使用)。 
无此属性视为此域允许空值。 
如:76fcbe9cf4728131adeaeefb1d19e404 
3、最大长度验证(可以和空值验证、一般验证方式同时使用): 
7090effba10d5a8d06f390b8f397dffa 
或,854d848c6aacabd3a6930a1f7cc1a264 
3、一般验证方式(不对空值做验证): 
如:2777422c368dfc08ffebbfa3b9685492 
4、标准验证(不与其它验证方式同时使用): 
全部通过6bfea39e2880ed1f176d4faec8788f49来实现,并且不需要name属性以免提交到服务器。 
4.1、合法日期验证: 
9f099c6201d78ef8ee979fbb0b7c3989注:这里也可以是9b9cce9d485fd856c764c3921a38610f18bb6ffaf0152bbe49cd8a3620346341,以下同 
b4795830b8b4fd6fe33ae8fd2d234040 
df4fff216f85eb215f7ab97dd263b85d 
3ecb2c31af449d6373db17a47a5d0b4a 
yearfieldName、monthfieldName、dayfieldName分别为年月日字段,月和日可以是两位(MM)或一位格式(M), 
此处不对每个字段分别检验(如果要检验,请在年月日三个域分别使用前面的一般验证方式),只对日期的最大值是否合法检查; 
4.2、日期格式验证(请注意,此验证不对日期是否有效进行验证,还未找到从格式中得到年月日数据的方法^_^): 
e39bbdac53c9b96d654d7948d309f01f 
638eebff72278424b873f6783e9246c5 
其中格式仅对y、M、d、H、m、s进行支持(其它字符视为非时间的字符) 
4.3、列表验证: 
检验列表(checkbox、redio、select)是否至少选中了一条记录(对select主要用于多项选择) 
ecea8bd3ab8f002a9c08f722f3de1b48 
f82e4b74eb30432400fb7d6aad45b16a 
其中validatorType可以是Checkbox、R、Select; 
对于一个select表单,如果要求选择一条不能是第一条的记录,请用下列方式: 
aa3674743b1815f1e225c0b86905bf0a 
deb802d11e8b0cc341f68c280f65dae7==请选择==4afa15d3069109ac30911f04c56f3338 
22d7eb427e1a7079cd01008d37a3299c14afa15d3069109ac30911f04c56f3338 
221f08282418e2996498697df914ce4e 
4.4、Email验证: 
596bff45a69e9abd8468b4bbd281de7b 
3742f6d40f21f1d20e29773a96316594 
其中separator为可选项,表示输入多个email时的分隔符(无此选项只能是一个地址) 
4.5、加入其它javascript操作: 
5cd6e472395e766622bc5d31b556eb7a 
function functionname(){ 
自定义方法 

2cacc6d41bbb37262a98f745aa00fbf0 
表单中加入3f7460748f8d32895f1ba4c9cbc19d31(此时emptyInfo等属性无效) 
时将调用function属性中指定的javascript方法(要求方法返回true或false,返回false将不再验证表单,也不提交表单)。 
5、在表单通过验证提交前disable一个按钮(也可将其它域disable,不能与其它验证同在一个域),不要求按钮是表单中的最后一个 
065ed6893513df288c1961d1c785b207 
6、不验证表单 
a18c8eb901ff34e0ea4ac896a352fbf5 
当validator域值为0时不对表单进行验证,直接提交表单或执行指定function并返回true后提交表单 
functionName为可选 
--> 

<script type="text/javascript"> 
function getStringLength(str){ 
var endvalue=0; 
var sourcestr=new String(str); 
var tempstr; 
for (var strposition = 0; strposition < sourcestr.length; strposition ++) { 
tempstr=sourcestr.charAt(strposition); 
if (tempstr.charCodeAt(0)>255 || tempstr.charCodeAt(0)<0) { 
endvalue=endvalue+2; 
} else { 
endvalue=endvalue+1; 
} 
} 
return(endvalue); 
} 
function trim(str){ 
if(str==null) return ""; 
if(str.length==0) return ""; 
var i=0,j=str.length-1,c; 
for(;i<str.length;i++){ 
c=str.charAt(i); 
if(c!=&#39; &#39;) break; 
} 
for(;j>-1;j--){ 
c=str.charAt(j); 
if(c!=&#39; &#39;) break; 
} 
if(i>j) return ""; 
return str.substring(i,j+1); 
} 
function validateDate(date,format,alt){ 
var time=trim(date.value); 
if(time=="") return; 
var reg=format; 
var reg=reg.replace(/yyyy/,"[0-9]{4}"); 
var reg=reg.replace(/yy/,"[0-9]{2}"); 
var reg=reg.replace(/MM/,"((0[1-9])|1[0-2])"); 
var reg=reg.replace(/M/,"(([1-9])|1[0-2])"); 
var reg=reg.replace(/dd/,"((0[1-9])|([1-2][0-9])|30|31)"); 
var reg=reg.replace(/d/,"([1-9]|[1-2][0-9]|30|31))"); 
var reg=reg.replace(/HH/,"(([0-1][0-9])|20|21|22|23)"); 
var reg=reg.replace(/H/,"([0-9]|1[0-9]|20|21|22|23)"); 
var reg=reg.replace(/mm/,"([0-5][0-9])"); 
var reg=reg.replace(/m/,"([0-9]|([1-5][0-9]))"); 
var reg=reg.replace(/ss/,"([0-5][0-9])"); 
var reg=reg.replace(/s/,"([0-9]|([1-5][0-9]))"); 
reg=new RegExp("^"+reg+"$"); 
if(reg.test(time)==false){//验证格式是否合法 
alert(alt); 
date.focus(); 
return false; 
} 
return true; 
} 
function validateDateGroup(year,month,day,alt){ 
var array=new Array(31,28,31,30,31,30,31,31,30,31,30,31); 
var y=parseInt(year.value); 
var m=parseInt(month.value); 
var d=parseInt(day.value); 
var maxday=array[m-1]; 
if(m==2){ 
if((y%4==0&&y%100!=0)||y%400==0){ 
maxday=29; 
} 
} 
if(d>maxday){ 
alert(alt); 
return false; 
} 
return true; 
} 
function validateCheckbox(obj,alt){ 
var rs=false; 
if(obj!=null){ 
if(obj.length==null){ 
return obj.checked; 
} 
for(i=0;i<obj.length;i++){ 
if(obj[i].checked==true){ 
return true; 
} 
} 
} 
alert(alt); 
return rs; 
} 
function validateRadio(obj,alt){ 
var rs=false; 
if(obj!=null){ 
if(obj.length==null){ 
return obj.checked; 
} 
for(i=0;i<obj.length;i++){ 
if(obj[i].checked==true){ 
return true; 
} 
} 
} 
alert(alt); 
return rs; 
} 
function validateSelect(obj,alt){ 
var rs=false; 
if(obj!=null){ 
for(i=0;i<obj.options.length;i++){ 
if(obj.options[i].selected==true){ 
return true; 
} 
} 
} 
alert(alt); 
return rs; 
} 
function validateEmail(email,alt,separator){ 
var mail=trim(email.value); 
if(mail=="") return; 
var em; 
var myReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/; 
if(separator==null){ 
if(myReg.test(email.value)==false){ 
alert(alt); 
email.focus(); 
return false; 
} 
} 
else{ 
em=email.value.split(separator); 
for(i=0;i<em.length;i++){ 
em[i]=em[i].trim(); 
if(em[i].length>0&&myReg.test(em[i])==false){ 
alert(alt); 
email.focus(); 
return false; 
} 
} 
} 
return true; 
} 
function validateForm(theForm){// 若验证通过则返回true 
var disableList=new Array(); 
var field = theForm.elements; // 将表单中的所有元素放入数组 
for(var i = 0; i < field.length; i++){ 
var vali=theForm.validate; 
if(vali!=null){ 
if(vali.value=="0"){ 
var fun=vali.functionName; 
if(fun!=null){ 
return eval(fun+"()"); 
} 
else{ 
return true; 
} 
} 
} 
var empty=false; 
var value=trim(field[i].value); 
if(value.length==0){//是否空值 
empty=true; 
} 
var emptyInfo=field[i].emptyInfo;//空值验证 
if(emptyInfo!=null&&empty==true){ 
alert(emptyInfo); 
field[i].focus(); 
return false; 
} 
var lengthInfo=field[i].lengthInfo;//最大长度验证 
if(lengthInfo!=null&&getStringLength(value)>field[i].maxLength){ 
alert(lengthInfo); 
field[i].focus(); 
return false; 
} 
var validatorType=field[i].validatorType; 
if(validatorType!=null){//其它javascript 
var rs=true; 
if(validatorType=="javascript"){ 
eval("rs="+field[i].functionName+"()"); 
if(rs==false){ 
return false; 
} 
else{ 
continue; 
} 
} 
else if(validatorType=="disable"){//提交表单前disable的按钮 
disableList.length++; 
disableList[disableList.length-1]=field[i]; 
continue; 
} 
else if(validatorType=="Date"){ 
rs=validateDate(theForm.elements(field[i].fieldName),field[i].format,field[i].errorInfo); 
} 
else if(validatorType=="DateGroup"){ 
rs=validateDateGroup(theForm.elements(field[i].year),theForm.elements(field[i].month),theForm.elements(field[i].day),field[i].errorInfo);
} 
else if(validatorType=="Checkbox"){ 
rs=validateCheckbox(theForm.elements(field[i].fieldName),field[i].errorInfo); 
} 
else if(validatorType=="Radio"){ 
rs=validateRadio(theForm.elements(field[i].fieldName),field[i].errorInfo); 
} 
else if(validatorType=="Select"){ 
rs=validateSelect(theForm.elements(field[i].fieldName),field[i].errorInfo); 
} 
else if(validatorType=="Email"){ 
rs=validateEmail(theForm.elements(field[i].fieldName),field[i].errorInfo); 
} 
else{ 
alert("验证类型不被支持, fieldName: "+field[i].name); 
return false; 
} 
if(rs==false){ 
return false; 
} 
} 
else{//一般验证 
if(empty==false){ 
var v = field[i].validator; // 获取其validator属性 
if(!v) continue; // 如果该属性不存在,忽略当前元素 
var reg=new RegExp(v); 
if(reg.test(field[i].value)==false){ 
alert(field[i].errorInfo); 
field[i].focus(); 
return false; 
} 
} 
} 
} 
for(i=0;i<disableList.length;i++){ 
disableList[i].disabled=true; 
} 
return true; 
} 
</script>


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.