js正则表达式

来源:互联网 发布:手机送货单软件 编辑:程序博客网 时间:2024/06/10 03:36

1.正则表达式基本语法

两个特殊的符号'^'和'$'。他们的作用是分别指出一个字符串的开始和结束。

例子如下:

"^The":表示所有以"The"开始的字符串("There","The cat"等);

"of despair$":表示所以以"of despair"结尾的字符串;

"^abc$":表示开始和结尾都是"abc"的字符串——呵呵,只有"abc"自己了;

"notice":表示任何包含"notice"的字符串。

象最后那个例子,如果你不使用两个特殊字符,你就在表示要查找的串在被查找串的任意部分——你并
不把它定位在某一个顶端。

其它还有'*','+'和'?'这三个符号,表示一个或一序列字符重复出现的次数。

它们分别表示“没有或更多”,“一次或更多”还有“没有或一次”。

下面是几个例子:

"ab*":表示一个字符串有一个a后面跟着零个或若干个b。("a", "ab", "abbb",……);

"ab+":表示一个字符串有一个a后面跟着至少一个b或者更多;

"ab?":表示一个字符串有一个a后面跟着零个或者一个b;

"a?b+$":表示在字符串的末尾有零个或一个a跟着一个或几个b。

你也可以使用范围,用大括号括起,用以表示重复次数的范围。

"ab{2}":表示一个字符串有一个a跟着2个b("abb");

"ab{2,}":表示一个字符串有一个a跟着至少2个b;

"ab{3,5}":表示一个字符串有一个a跟着3到5个b。

请注意,你必须指定范围的下限(如:"{0,2}"而不是"{,2}")。

还有,你可能注意到了,'*','+'和'?'相当于"{0,}","{1,}"和"{0,1}"。

还有一个'¦',表示“或”操作:

"hi¦hello":表示一个字符串里有"hi"或者"hello";

"(b¦cd)ef":表示"bef"或"cdef";

"(a¦b)*c":表示一串"a""b"混合的字符串后面跟一个"c";

'.'可以替代任何字符:

"a.[0-9]":表示一个字符串有一个"a"后面跟着一个任意字符和一个数字;

"^.{3}$":表示有任意三个字符的字符串(长度为3个字符);

方括号表示某些字符允许在一个字符串中的某一特定位置出现:

"[ab]":表示一个字符串有一个"a"或"b"(相当于"a¦b");

"[a-d]":表示一个字符串包含小写的'a'到'd'中的一个(相当于"a¦b¦c¦d"或者"[abcd]");

"^[a-zA-Z]":表示一个以字母开头的字符串;

"[0-9]%":表示一个百分号前有一位的数字;

",[a-zA-Z0-9]$":表示一个字符串以一个逗号后面跟着一个字母或数字结束。

你也可以在方括号里用'^'表示不希望出现的字符,'^'应在方括号里的第一位。

(如:"%[^a-zA-Z]%"表示两个百分号中不应该出现字母)。

为了逐字表达,你必须在"^.$()¦*+?{\"这些字符前加上转移字符'\'。

请注意在方括号中,不需要转义字符。

2.正则表达式验证控制文本框的输入字符类型

1.只能输入数字和英文的:

?
1
<input onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"ID="Text1"NAME="Text1">

2.只能输入数字的:

?
1
<input onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"ID="Text2"NAME="Text2">

3.只能输入全角的:

?
1
<input onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"ID="Text3"NAME="Text3">

4.只能输入汉字的:

?
1
<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"ID="Text4"NAME="Text4">

3.正则表达式的应用实例通俗说明

*******************************************************************************

//校验是否全由数字组成

/^[0-9]{1,20}$/

^ 表示打头的字符要匹配紧跟^后面的规则

$ 表示打头的字符要匹配紧靠$前面的规则

[ ] 中的内容是可选字符集

[0-9] 表示要求字符范围在0-9之间

{1,20}表示数字字符串长度合法为1到20,即为[0-9]中的字符出现次数的范围是1到20次。

/^ 和 $/成对使用应该是表示要求整个字符串完全匹配定义的规则,而不是只匹配字符串中的一个子串。

*******************************************************************************

//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串

/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/

^[a-zA-Z]{1} 表示第一个字符要求是字母。

([a-zA-Z0-9]|[._]){4,19} 表示从第二位开始(因为它紧跟在上个表达式后面)的一个长度为4到9位的字符串,它要求是由大小写字母、数字或者特殊字符集[._]组成。

*******************************************************************************

//校验用户姓名:只能输入1-30个以字母开头的字串

/^[a-zA-Z]{1,30}$/ 

*******************************************************************************

//校验密码:只能输入6-20个字母、数字、下划线

/^(\w){6,20}$/

\w:用于匹配字母,数字或下划线字符 

*******************************************************************************

//校验普通电话、传真号码:可以“+”或数字开头,可含有“-” 和 “ ”

/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/

\d:用于匹配从0到9的数字;

“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次

可以匹配的字符串如:+123 -999 999 ; +123-999 999 ;123 999 999 ;+123 999999等

*******************************************************************************
//校验URL

/^http[s]{0,1}:\/\/.+$/ 或 /^http[s]{0,1}:\/\/.{1,n}$/ (表示url串的长度为length(“https://”) + n )
 \ / :表示字符“/”。

. 表示所有字符的集

+ 等同于{1,},就是1到正无穷吧。

 *******************************************************************************

//校验纯中文字符
/

^[\u4E00-\u9FA5]+$/

[\u4E00-\u9FA5] :估计是中文字符集的范围吧

以上表达式均在下面的javascript中测试通过

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<html>
<script language="JavaScript">
<!--
functionregx(r,s)
{
    if(r ==null || r == ""){
       returnfalse;
    }
    varpatrn=new RegExp(r);
    if(patrn.exec(s))
       returntrue
    returnfalse
}
  
-->
</script>
<body>
<form>

规则表达式 :

?
1
2
<input type="input"name="regxStr"value="" > (填写/ /之间的表达式)
<br>

校验字符串 :

?
1
2
3
4
5
<input type="input"name="str"value="" >
    <input type="button"name="match"value="匹配" onClick="alert(regx(regxStr.value,str.value));">
</form>
</body>
</html>

4.正則表達式應用

"^\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

/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/   //  年-月-日

/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/   // 月/日/年

"^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"   //Emil

"(d+-)?(d{4}-?d{7}|d{3}-?d{8}|^d{7,8})(-d+)?"     //电话号码

"^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$"   //IP地址

^([0-9A-F]{2})(-[0-9A-F]{2}){5}$   //MAC地址的正则表达式

^[-+]?\d+(\.\d+)?$  //值类型正则表达式

5.javascript正则表达式检验

//校验是否全由数字组成

?
1
2
3
4
5
6
functionisDigit(s)
{
varpatrn=/^[0-9]{1,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串

?
1
2
3
4
5
6
functionisRegisterUserName(s)
{
varpatrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验用户姓名:只能输入1-30个以字母开头的字串

?
1
2
3
4
5
6
functionisTrueName(s)
{
varpatrn=/^[a-zA-Z]{1,30}$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验密码:只能输入6-20个字母、数字、下划线

?
1
2
3
4
5
6
functionisPasswd(s)
{
varpatrn=/^(\w){6,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”

?
1
2
3
4
5
6
7
functionisTel(s)
{
//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/;
varpatrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验手机号码:必须以数字开头,除数字外,可含有“-”

?
1
2
3
4
5
6
functionisMobil(s)
{
varpatrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验邮政编码

?
1
2
3
4
5
6
7
functionisPostalCode(s)
{
//var patrn=/^[a-zA-Z0-9]{3,12}$/;
varpatrn=/^[a-zA-Z0-9 ]{3,12}$/;
if(!patrn.exec(s))returnfalse
returntrue
}

//校验搜索关键字



124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
functionisSearch(s)
{
varpatrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;\'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;\'\,.<>?]{0,19}$/;
if(!patrn.exec(s))returnfalse
returntrue
}
functionisIP(s)//by zergling
{
varpatrn=/^[0-9.]{1,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}
  
/*********************************************************************************
* FUNCTION: isBetween
* PARAMETERS: val AS any value
* lo AS Lower limit to check
* hi AS Higher limit to check
* CALLS: NOTHING
* RETURNS: TRUE if val is between lo and hi both inclusive, otherwise false.
**********************************************************************************/
functionisBetween (val, lo, hi) {
if((val < lo) || (val > hi)) {return(false); }
else{return(true); }
}
/*********************************************************************************
* FUNCTION: isDate checks a valid date
* PARAMETERS: theStr AS String
* CALLS: isBetween, isInt
* RETURNS: TRUE if theStr is a valid date otherwise false.
**********************************************************************************/
functionisDate (theStr) {
varthe1st = theStr.indexOf('-');
var the2nd = theStr.lastIndexOf('-');
if (the1st == the2nd) { return(false); }
else {
var y = theStr.substring(0,the1st);
var m = theStr.substring(the1st+1,the2nd);
var d = theStr.substring(the2nd+1,theStr.length);
var maxDays = 31;
if (isInt(m)==false || isInt(d)==false || isInt(y)==false) {
return(false); }
else if (y.length < 4) { return(false); }
else if (!isBetween (m, 1, 12)) { return(false); }
else if (m==4 || m==6 || m==9 || m==11) maxDays = 30;
else if (m==2) {
if (y % 4 > 0) maxDays = 28;
else if (y % 100 == 0 && y % 400 > 0) maxDays = 28;
else maxDays = 29;
}
if (isBetween(d, 1, maxDays) == false) { return(false); }
else { return(true); }
}
}
/*********************************************************************************
* FUNCTION: isEuDate checks a valid date in British format
* PARAMETERS: theStr AS String
* CALLS: isBetween, isInt
* RETURNS: TRUE if theStr is a valid date otherwise false.
**********************************************************************************/
function isEuDate (theStr) {
if (isBetween(theStr.length, 8, 10) == false) { return(false); }
else {
var the1st = theStr.indexOf('/');
var the2nd = theStr.lastIndexOf('/');
if (the1st == the2nd) { return(false); }
else {
var m = theStr.substring(the1st+1,the2nd);
var d = theStr.substring(0,the1st);
var y = theStr.substring(the2nd+1,theStr.length);
var maxDays = 31;
if (isInt(m)==false || isInt(d)==false || isInt(y)==false) {
return(false); }
else if (y.length < 4) { return(false); }
else if (isBetween (m, 1, 12) == false) { return(false); }
else if (m==4 || m==6 || m==9 || m==11) maxDays = 30;
else if (m==2) {
if (y % 4 > 0) maxDays = 28;
else if (y % 100 == 0 && y % 400 > 0) maxDays = 28;
else maxDays = 29;
}
if (isBetween(d, 1, maxDays) == false) { return(false); }
else { return(true); }
}
}
}
/********************************************************************************
* FUNCTION: Compare Date! Which is the latest!
* PARAMETERS: lessDate,moreDate AS String
* CALLS: isDate,isBetween
* RETURNS: TRUE if lessDate<moreDate
*********************************************************************************/
function isComdate (lessDate , moreDate)
{
if (!isDate(lessDate)) { return(false);}
if (!isDate(moreDate)) { return(false);}
var less1st = lessDate.indexOf('-');
var less2nd = lessDate.lastIndexOf('-');
var more1st = moreDate.indexOf('-');
var more2nd = moreDate.lastIndexOf('-');
var lessy = lessDate.substring(0,less1st);
var lessm = lessDate.substring(less1st+1,less2nd);
var lessd = lessDate.substring(less2nd+1,lessDate.length);
var morey = moreDate.substring(0,more1st);
var morem = moreDate.substring(more1st+1,more2nd);
var mored = moreDate.substring(more2nd+1,moreDate.length);
var Date1 = new Date(lessy,lessm,lessd);
var Date2 = new Date(morey,morem,mored);
if (Date1>Date2) { return(false);}
return(true);
}
/*********************************************************************************
* FUNCTION isEmpty checks if the parameter is empty or null
* PARAMETER str AS String
**********************************************************************************/
function isEmpty (str) {
if ((str==null)||(str.length==0)) return true;
else return(false);
}
/*********************************************************************************
* FUNCTION: isInt
* PARAMETER: theStr AS String
* RETURNS: TRUE if the passed parameter is an integer, otherwise FALSE
* CALLS: isDigit
**********************************************************************************/
function isInt (theStr) {
var flag = true;
if (isEmpty(theStr)) { flag=false; }
else
{ for (var i=0; i<theStr.length; i++) {
if (isDigit(theStr.substring(i,i+1)) == false) {
flag = false; break;
}
}
}
return(flag);
}
/*********************************************************************************
* FUNCTION: isReal
* PARAMETER: heStr AS String
decLen AS Integer (how many digits after period)
* RETURNS: TRUE if theStr is a float, otherwise FALSE
* CALLS: isInt
**********************************************************************************/
function isReal (theStr, decLen) {
var dot1st = theStr.indexOf('.');
var dot2nd = theStr.lastIndexOf('.');
var OK = true;
if (isEmpty(theStr)) return false;
if (dot1st == -1) {
if (!isInt(theStr)) return(false);
else return(true);
}
else if (dot1st != dot2nd) return (false);
else if (dot1st==0) return (false);
else {
var intPart = theStr.substring(0, dot1st);
var decPart = theStr.substring(dot2nd+1);
if (decPart.length > decLen) return(false);
else if (!isInt(intPart) || !isInt(decPart)) return (false);
else if (isEmpty(decPart)) return (false);
else return(true);
}
}
/*********************************************************************************
* FUNCTION: isEmail
* PARAMETER: String (Email Address)
* RETURNS: TRUE if the String is a valid Email address
* FALSE if the passed string is not a valid Email Address
* EMAIL FORMAT: AnyName@EmailServer e.g; webmaster@hotmail.com
* @ sign can appear only once in the email address.
*********************************************************************************/
function isEmail (theStr) {
var atIndex = theStr.indexOf('@');
var dotIndex = theStr.indexOf('.', atIndex);
var flag = true;
theSub = theStr.substring(0, dotIndex+1)
if ((atIndex < 1)||(atIndex != theStr.lastIndexOf('@'))||(dotIndex < atIndex + 2)||(theStr.length <= theSub.length))
{return(false); }
else{return(true); }
}
/*********************************************************************************
* FUNCTION: newWindow
* PARAMETERS: doc -> Document to open in the new window
hite -> Height of the new window
wide -> Width of the new window
bars -> 1-Scroll bars = YES 0-Scroll Bars = NO
resize -> 1-Resizable = YES 0-Resizable = NO
* CALLS: NONE
* RETURNS: New window instance
**********************************************************************************/
functionnewWindow (doc, hite, wide, bars, resize) {
varwinNew="_blank";
varopt="toolbar=0,location=0,directories=0,status=0,menubar=0,";
opt+=("scrollbars="+bars+",");
opt+=("resizable="+resize+",");
opt+=("width="+wide+",");
opt+=("height="+hite);
winHandle=window.open(doc,winNew,opt);
return;
}
/*********************************************************************************
* FUNCTION: DecimalFormat
* PARAMETERS: paramValue -> Field value
* CALLS: NONE
* RETURNS: Formated string
**********************************************************************************/
functionDecimalFormat (paramValue) {
varintPart = parseInt(paramValue);
vardecPart =parseFloat(paramValue) - intPart;
str ="";
if((decPart == 0) || (decPart ==null)) str += (intPart +".00");
elsestr += (intPart + decPart);
return(str);
}

 "^\\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

以上就是给大家分享的正则表达式基本语法,希望对大家学习有所帮助。


js正则表达式中test,exec,match方法的区别说明

test
test 返回 Boolean,查找对应的字符串中是否存在模式。
var str = "1a1b1c";
var reg = new RegExp("1.", "");
alert(reg.test(str)); // true


exec
exec 查找并返回当前的匹配结果,并以数组的形式返回。
var str = "1a1b1c";
var reg = new RegExp("1.", "");
var arr = reg.exec(str);
如果不存在模式,则 arr 为 null,否则 arr 总是一个长度为 1 的数组,其值就是当前匹配项。arr 还有三个属性:index 当前匹配项的位置;lastIndex 当前匹配项结束的位置(index + 当前匹配项的长度);input 如上示例中 input 就是 str。


exec 方法受参数 g 的影响。若指定了 g,则下次调用 exec 时,会从上个匹配的 lastIndex 开始查找。
var str = "1a1b1c";
var reg = new RegExp("1.", "");
alert(reg.exec(str)[0]);
alert(reg.exec(str)[0]);
上述两个输出都是 1a。现在再看看指定参数 g:
var str = "1a1b1c";
var reg = new RegExp("1.", "g");
alert(reg.exec(str)[0]);
alert(reg.exec(str)[0]);
上述第一个输出 1a,第二个输出 1b。


match
match 是 String 对象的一个方法。
var str = "1a1b1c";
var reg = new RegExp("1.", "");
alert(str.match(reg));
match 这个方法有点像 exec,但:exec 是 RegExp 对象的方法;math 是 String 对象的方法。二者还有一个不同点,就是对参数 g 的解释。
如果指定了参数 g,那么 match 一次返回所有的结果。
var str = "1a1b1c";
var reg = new RegExp("1.", "g");
alert(str.match(reg));
//alert(str.match(reg)); // 此句同上句的结果是一样的
此结果为一个数组,有三个元素,分别是:1a、1b、1c。

JavaScript中经常用到正则表达式, 而正则表达式中经常用到Match和Test这两个函数,当然还有Exec. 这里以代码实例来区分它们之间的不同吧.

Match Example

复制代码 代码如下:

var str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
var regexp = /[A-E]/gi;
var rs = str.match(regexp);
//rs= Array('A', 'B', 'C', 'D', 'E', 'a', 'b', 'c', 'd', 'e');

Test Example
复制代码 代码如下:

var str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
var regexp = /[A-E]/gi;
var rs = regexp.test(str);
// rs = true; boolean

Exc Example
复制代码 代码如下:

var str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
var regexp = /[A-E]/gi;
var rs;
while ((rs = regexp.exec(str)) != null)
{
    document.write(rs);
    document.write(regexp.lastIndex);
    document.write("<br />");
}

OUTPUT
---------------------------------
A    1
B   2
C   3
D   4
E   5
a   27
b   28
c   29
d   30
e   31


Another   Exc Example
复制代码 代码如下:

var regexp = /ab*/g;
var str = "abbcdefabh";
var rs;
while ((rs = regexp.exec(str)) != null)
{
    document.write(rs);
    document.write(regexp.lastIndex);
    document.write("<br />");
}

OUTPUT
---------------------------------
abb   3
ab     9



补充:

<script>
var weight=parseInt(prompt("请输入体重(kg):"));
var height=parseFloat(prompt("请输入身高(m):"));
var s=weight/(height*height);
if(s<25)
{
if(s<20)
{
alert('偏瘦');
}
else{
alert('正常');
}
}
else{
alert('偏胖')
}
</script>

 

js弹出框、对话框、提示框、弹窗总结


一、JS的三种最常见的对话框

[javascript] view plaincopy
  1. //====================== JS最常用三种弹出对话框 ========================  
  2.   
  3.     //弹出对话框并输出一段提示信息  
  4.     function ale() {  
  5.         //弹出一个对话框  
  6.         alert("提示信息!");  
  7.   
  8.     }  
  9.   
  10.     //弹出一个询问框,有确定和取消按钮  
  11.     function firm() {  
  12.         //利用对话框返回的值 (true 或者 false)  
  13.         if (confirm("你确定提交吗?")) {  
  14.             alert("点击了确定");  
  15.         }  
  16.         else {  
  17.             alert("点击了取消");  
  18.         }  
  19.   
  20.     }  
  21.   
  22.     //弹出一个输入框,输入一段文字,可以提交  
  23.     function prom() {  
  24.         var name = prompt("请输入您的名字"""); //将输入的内容赋给变量 name ,  
  25.   
  26.         //这里需要注意的是,prompt有两个参数,前面是提示的话,后面是当对话框出来后,在对话框里的默认值  
  27.         if (name)//如果返回的有内容  
  28.         {  
  29.             alert("欢迎您:" + name)  
  30.         }  
  31.   
  32.     }  

二、点击按钮时常用的6中提示框和操作

[html] view plaincopy
  1. <!-----------按钮提示框---------->  
  2. <input type="button" name="btn2" id="btn2" value="删除" onclick="return confirm('Yes/No'););  
  3.   
  4. <!-----------按钮提示框---------->   
  5. <input type="button" name="btn2" id="btn2" value="提示" onclick="javaScript:alert('您确定要删除吗?');  
  6.   
  7. <!-----------提交按钮---------->   
  8. <input type="button" value="提交" onclick="javaScript:window.location.href='http://www.baidu.com';"/>  
  9.   
  10. <!-----------关闭按钮---------->   
  11. <input type="button" value="关闭" onclick="javaScript:window.close();">  
  12.   
  13. <!-----------返回并关闭连接---------->   
  14. <a href="#" onclick="javascript:;window.opener.location.reload();window.close()">返回</a>  
  15. javaScript:window.location.reload();//返回当前页并刷新  
  16.   
  17. <!-----------返回上一级页面---------->   
  18. <input type="button" name="button" value="< 返回" onclick="javascript:history.go(-1)"/>  

三、弹出独立窗口

[javascript] view plaincopy
  1. //关闭,父窗口弹出对话框,子窗口直接关闭   
  2. this.Response.Write("<script language=javascript>window.close();</script>");  
  3.   
  4. //关闭,父窗口和子窗口都不弹出对话框,直接关闭   
  5. this.Response.Write("<script>");   
  6. this.Response.Write("{top.opener =null;top.close();}");   
  7. this.Response.Write("</script>");  
  8.   
  9. //弹出窗口刷新当前页面width=200 height=200菜单。菜单栏,工具条,地址栏,状态栏全没有   
  10. this.Response.Write("<script language=javascript>window.open('rows.aspx','newwindow','width=200,height=200')</script>");  
  11.   
  12. //弹出窗口刷新当前页面   
  13. this.Response.Write("<script language=javascript>window.open('rows.aspx')</script>");  
  14. this.Response.Write("<script>window.open('WebForm2.aspx','_blank');</script>");  
  15.   
  16. //弹出提示窗口跳到webform2.aspx页(在一个IE窗口中)   
  17. this.Response.Write(" <script language=javascript>alert('注册成功');window.window.location.href='WebForm2.aspx';</script> ");  
  18.   
  19. //关闭当前子窗口,刷新父窗口   
  20. this.Response.Write("<script>window.opener.location.href=window.opener.location.href;window.close();</script>");  
  21. this.Response.Write("<script>window.opener.location.replace(window.opener.document.referrer);window.close();</script>");  
  22.   
  23. //子窗口刷新父窗口   
  24. this.Response.Write("<script>window.opener.location.href=window.opener.location.href;</script>");  
  25. this.Response.Write("<script>window.opener.location.href='WebForm1.aspx';</script>");  
  26.   
  27. //弹出提示窗口.确定后弹出子窗口(WebForm2.aspx)   
  28. this.Response.Write("<script language='javascript'>alert('发表成功!');window.open('WebForm2.aspx')</script>");  
  29.   
  30. //弹出提示窗口,确定后,刷新父窗口   
  31. this.Response.Write("<script>alert('发表成功!');window.opener.location.href=window.opener.location.href;</script>");  
  32.   
  33. //弹出相同的一页   
  34. <INPUT type="button" value="Button" onclick="javascript:window.open(window.location.href)">  
  35.   
  36. //   
  37. Response.Write("parent.mainFrameBottom.location.href='yourwebform.aspx?temp=" +str+"';");  
  38.   
  39.   
  40. <SCRIPT LANGUAGE="javascript">   
  41. <!--   
  42. window.open ('page.html''newwindow''height=100, width=400, top=0, left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=n o, status=no'//这句要写成一行  
  43. -->   

   参数解释:

window.open 弹出新窗口的命令; 
'page.html' 弹出窗口的文件名; 
'newwindow' 弹出窗口的名字(不是文件名),非必须,可用空''代替; 
  height=100 窗口高度; 
  width=400 窗口宽度; 
  top=0 窗口距离屏幕上方的象素值; 
  left=0 窗口距离屏幕左侧的象素值; 
  toolbar=no 是否显示工具栏,yes为显示; 
  menubar,scrollbars 表示菜单栏和滚动栏。 
  resizable=no 是否允许改变窗口大小,yes为允许; 
  location=no 是否显示地址栏,yes为允许; 
  status=no 是否显示状态栏内的信息(通常是文件已经打开),yes为允许;

'newwin':隐藏菜单栏地址栏工具条 

四、弹出窗口实例演示

[javascript] view plaincopy
  1.   //1、最基本的弹出窗口代码  
  2.   
  3. window.open ('page.html')   
  4.   
  5.   
  6.   //2、经过设置后的弹出窗口  
  7.   
  8. window.open('page.html''newwindow''height=100, width=400, top=0, left=0, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=n o, status=no'//这句要写成一行  
  9.   
  10.    
  11. //参数解释:   
  12. //window.open 弹出新窗口的命令;   
  13. //'page.html' 弹出窗口的文件名;   
  14. //'newwindow' 弹出窗口的名字(不是文件名),非必须,可用空''代替;   
  15. //height=100 窗口高度;   
  16. //width=400 窗口宽度;   
  17. //top=0 窗口距离屏幕上方的象素值;   
  18. //left=0 窗口距离屏幕左侧的象素值;   
  19. //toolbar=no 是否显示工具栏,yes为显示;   
  20. //menubar,scrollbars 表示菜单栏和滚动栏。   
  21. //resizable=no 是否允许改变窗口大小,yes为允许;   
  22. //location=no 是否显示地址栏,yes为允许;   
  23. //status=no 是否显示状态栏内的信息(通常是文件已经打开),yes为允许;   
  24.    
  25.   //3、用函数控制弹出窗口  
  26.   
  27. function openwin() {  
  28.     window.open("page.html""newwindow""height=100, width=400, toolbar =no, menubar=no, scrollbars=no, resizable=no, location=no, status=no"//写成一行  
  29. }   
  30.   $(document).ready(fucntion(){  
  31.       openwin();  
  32.   });  
  33.   
  34. //这里定义了一个函数openwin(),函数内容就是打开一个窗口。在调用它之前没有任何用途。怎么调用呢?  
  35.   
  36. //方法一:<body onload="openwin()"> 浏览器读页面时弹出窗口;   
  37. //方法二:<body onunload="openwin()"> 浏览器离开页面时弹出窗口;   
  38. //方法三:用一个连接调用:   
  39. //<a href="#" onclick="openwin()">打开一个窗口</a>   
  40. //注意:使用的“#”是虚连接。   
  41. //方法四:用一个按钮调用:   
  42. //<input type="button" onclick="openwin()" value="打开窗口">   
  43.   
  44.   //4、同时弹出2个窗口   
  45.    
  46.     function openwin() {  
  47.         window.open("page.html""newwindow""height=100, width=100, top=0, left=0,toolbar=no, menubar=no, scrollbars=no, resizable=no, location=n o, status=no")//写成一行  
  48.         window.open("page2.html""newwindow2""height=100, width=100, top=1 00, left=100,toolbar=no, menubar=no, scrollbars=no, resizable=no, loca tion=no, status=no")//写成一行  
  49.     }   
  50.   
  51. //为避免弹出的2个窗口覆盖,用top和left控制一下弹出的位置不要相互覆盖即可 。最后用上面说过的四种方法调用即可。   
  52. //注意:2个窗口的name(newwindows和newwindow2)不要相同,或者干脆全部为空。  
  53.   
  54.   //5、主窗口打开文件1.htm,同时弹出小窗口page.html  
  55.   
  56.     function openwin() {  
  57.         window.open("page.html""""width=200,height=200")  
  58.     }    
  59.   
  60. //调用:<a href="1.htm" onclick="openwin()">open</a>  
  61.    
  62.   //6、弹出的窗口之定时关闭控制  
  63.    
  64. //下面我们再对弹出的窗口进行一些控制,效果就更好了。如果我们再将一小段 代码加入弹出的页面(注意是加入page.html的HTML中,不是主页面中),让它10秒后自动关闭是不是更酷了?  
  65.   //首先,将如下代码加入page.html文件的<head>区:   
  66.   function closeit() {  
  67.       setTimeout("self.close()", 10000) //毫秒   
  68.   }   
  69.   //页面加载完成调用关闭事件  
  70. $(document).ready(fucntion(){  
  71.       closeit();  
  72.   });  
  73.   
  74.   //7、在弹出窗口中加上一个关闭按钮  
  75.   
  76.   //<INPUT TYPE='BUTTON' VALUE='关闭' onClick='window.close()'>   
  77.   
  78.   
  79.   //8、内包含的弹出窗口-一个页面两个窗口  
  80.   
  81. //上面的例子都包含两个窗口,一个是主窗口,另一个是弹出的小窗口。通过下面的例子,你可以在一个页面内完成上面的效果。  
  82.   
  83.     function openwin() {  
  84.         OpenWindow = window.open("""newwin""height=250, width=250,toolbar=no ,scrollbars=" + scroll + ",menubar=no");  
  85.         //写成一行   
  86.         OpenWindow.document.write("<TITLE>例子</TITLE>")  
  87.         OpenWindow.document.write("<BODY BGCOLOR=#ffffff>")  
  88.         OpenWindow.document.write("<h1>Hello!</h1>")  
  89.         OpenWindow.document.write("New window opened!")  
  90.         OpenWindow.document.write("</BODY>")  
  91.         OpenWindow.document.write("</HTML>")  
  92.         OpenWindow.document.close()  
  93.     }   
  94.   
  95. //<a href="#" onclick="openwin()">打开一个窗口</a>   
  96. //<input type="button" onclick="openwin()" value="打开窗口">   
  97.   
  98.   
  99.   //9、终极应用--弹出的窗口之Cookie控制  
  100.   
  101. //回想一下,上面的弹出窗口虽然酷,但是有一点小毛病,比如你将上面的脚本放在一个需要频繁经过的页面里(例如首页),那么每次刷新这个页面,窗口都会弹出一次,我们使用cookie来控制一下就可以了。  
  102. //首先,将如下代码加入主页面HTML的<HEAD>区:  
  103.   
  104.     function openwin() {  
  105.         window.open("page.html""""width=200,height=200")  
  106.     }  
  107.     function get_cookie(Name) {  
  108.         var search = Name + "="  
  109.         var returnvalue = "";  
  110.         if (document.cookie.length > 0) {  
  111.             offset = document.cookie.indexOf(search)  
  112.             if (offset != -1) {  
  113.                 offset += search.length  
  114.                 end = document.cookie.indexOf(";", offset);  
  115.                 if (end == -1)  
  116.                     end = document.cookie.length;  
  117.                 returnvalue = unescape(document.cookie.substring(offset, end))  
  118.             }  
  119.         }  
  120.         return returnvalue;  
  121.     }  
  122.     function loadpopup() {  
  123.         if (get_cookie('popped') == '') {  
  124.             openwin()  
  125.             document.cookie = "popped=yes"  
  126.         }  
  127.     }   
  128.   
  129. //然后,用<body onload="loadpopup()">(注意不是openwin而是loadpop啊!)替换主页面中原有的<BODY>这一句即可。你可以试着刷新一下这个页面或重新进入该页面,窗口再也不会弹出了。真正的Pop-Only-Once!  


原创粉丝点击