js 正则表达式

//校验是否全由数字组成 
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=/^[^`~!@#$%^&*()+=|///][/]/{/}:;'/,.<>/?]{1}[^`~!@$%^&()+=|///][/]/{/}:;'/,.<>?]{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 





正则表达式 
"^//d+$"  //非负整数(正整数 + 0) 
"^[0-9]*[1-9][0-9]*$"  //正整数 
"^((-//d+)|(0+))$"  //非正整数(负整数 + 0) 
"^-[0-9]*[1-9][0-9]*$"  //负整数 
"^-?//d+$"    //整数 
"^//d+(file://.//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+(file://.//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+)(file://.//d+)?$"  //浮点数 
"^[A-Za-z]+$"  //由26个英文字母组成的字符串 
"^[A-Z]+$"  //由26个英文字母的大写组成的字符串 
"^[a-z]+$"  //由26个英文字母的小写组成的字符串 
"^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串 
"^//w+$"  //由数字、26个英文字母或者下划线组成的字符串 
"^[//w-]+(file://.[//w-]+)*@[//w-]+(//.[//w-]+)+$"    //email地址 
"^[a-zA-z]+://(file://w+(-//w+)*)(//.(//w+(-//w+)*))*(//?//S*)?$"  //url 


"^[A-Za-z0-9_]*$" 




正则表达式使用详解 


简介 
简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。其作用如下: 
测试字符串的某个模式。例如,可以对一个输入字符串进行测试,看在该字符串是否存在一个电话号码模式或一个信用卡号码模式。这称为数据有效性验证。 
替换文本。可以在文档中使用一个正则表达式来标识特定文字,然后可以全部将其删除,或者替换为别的文字。 
根据模式匹配从字符串中提取一个子字符串。可以用来在文本或输入字段中查找特定文字。 


基本语法 
在对正则表达式的功能和作用有了初步的了解之后,我们就来具体看一下正则表达式的语法格式。 
正则表达式的形式一般如下:   
/love/  其中位于"/”定界符之间的部分就是将要在目标对象中进行匹配的模式。用户只要把希望查找匹配对象的模式内容放入"/”定界符之间即可。为了能够使用户更加灵活的定制模式内容,正则表达式提供了专门的"元字符”。所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符)在目标对象中的出现模式。 
较为常用的元字符包括: "+”, "*”,以及 "?”。 
"+”元字符规定其前导字符必须在目标对象中连续出现一次或多次。 
"*”元字符规定其前导字符必须在目标对象中出现零次或连续多次。 
"?”元字符规定其前导对象必须在目标对象中连续出现零次或一次。 
下面,就让我们来看一下正则表达式元字符的具体应用。 
/fo+/  因为上述正则表达式中包含"+”元字符,表示可以与目标对象中的 "fool”, "fo”, 或者 "football”等在字母f后面连续出现一个或多个字母o的字符串相匹配。 
/eg*/  因为上述正则表达式中包含"*”元字符,表示可以与目标对象中的 "easy”, "ego”, 或者 "egg”等在字母e后面连续出现零个或多个字母g的字符串相匹配。 
/Wil?/  因为上述正则表达式中包含"?”元字符,表示可以与目标对象中的 "Win”, 或者"Wilson”,等在字母i后面连续出现零个或一个字母l的字符串相匹配。 
有时候不知道要匹配多少字符。为了能适应这种不确定性,正则表达式支持限定符的概念。这些限定符可以指定正则表达式的一个给定组件必须要出现多少次才能满足匹配。 
{n} n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。 
{n,} n 是一个非负整数。至少匹配 n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。 
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。 


除了元字符之外,用户还可以精确指定模式在匹配对象中出现的频率。例如,/jim {2,6}/ 上述正则表达式规定字符m可以在匹配对象中连续出现2-6次,因此,上述正则表达式可以同jimmy或jimmmmmy等字符串相匹配。 
在对如何使用正则表达式有了初步了解之后,我们来看一下其它几个重要的元字符的使用方式。 
/s:用于匹配单个空格符,包括tab键和换行符; 
/S:用于匹配除单个空格符之外的所有字符; 
/d:用于匹配从0到9的数字; 
/w:用于匹配字母,数字或下划线字符; 
/W:用于匹配所有与/w不匹配的字符; 
. :用于匹配除换行符之外的所有字符。 
(说明:我们可以把/s和/S以及/w和/W看作互为逆运算) 
下面,我们就通过实例看一下如何在正则表达式中使用上述元字符。 
//s+/ 上述正则表达式可以用于匹配目标对象中的一个或多个空格字符。 
//d000/ 如果我们手中有一份复杂的财务报表,那么我们可以通过上述正则表达式轻而易举的查找到所有总额达千元的款项。 
除了我们以上所介绍的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。定位符用于规定匹配模式在目标对象中的出现位置。 较为常用的定位符包括: "^”, "$”, "/b” 以及 "/B”。 
"^”定位符规定匹配模式必须出现在目标字符串的开头 
"$”定位符规定匹配模式必须出现在目标对象的结尾 
"/b”定位符规定匹配模式必须出现在目标字符串的开头或结尾的两个边界之一 
"/B”定位符则规定匹配对象必须位于目标字符串的开头和结尾两个边界之内,即匹配对象既不能作为目标字符串的开头,也不能作为目标字符串的结尾。同样,我们也可以把"^”和"$”以及"/b”和"/B”看作是互为逆运算的两组定位符。举例来说: /^hell/ 因为上述正则表达式中包含"^”定位符,所以可以与目标对象中以 "hell”, "hello”或"hellhound”开头的字符串相匹配。 /ar$/ 因为上述正则表达式中包含"$”定位符,所以可以与目标对象中以 "car”, "bar”或 "ar” 结尾的字符串相匹配。 //bbom/ 因为上述正则表达式模式以"/b”定位符开头,所以可以与目标对象中以 "bomb”, 或 "bom”开头的字符串相匹配。/man/b/ 因为上述正则表达式模式以"/b”定位符结尾,所以可以与目标对象中以 "human”, "woman”或 "man”结尾的字符串相匹配。 
为了能够方便用户更加灵活的设定匹配模式,正则表达式允许使用者在匹配模式中指定某一个范围而不局限于具体的字符。例如: 
/[A-Z]/  上述正则表达式将会与从A到Z范围内任何一个大写字母相匹配。 
/[a-z]/  上述正则表达式将会与从a到z范围内任何一个小写字母相匹配。 
/[0-9]/  上述正则表达式将会与从0到9范围内任何一个数字相匹配。 
/([a-z][A-Z][0-9])+/  上述正则表达式将会与任何由字母和数字组成的字符串,如 "aB0” 等相匹配。这里需要提醒用户注意的一点就是可以在正则表达式中使用 "()” 把字符串组合在一起。"()”符号包含的内容必须同时出现在目标对象中。因此,上述正则表达式将无法与诸如 "abc”等的字符串匹配,因为"abc”中的最后一个字符为字母而非数字。
如果我们希望在正则表达式中实现类似编程逻辑中的"或”运算,在多个不同的模式中任选一个进行匹配的话,可以使用管道符 "|”。例如:/to|too|2/ 上述正则表达式将会与目标对象中的 "to”, "too”, 或 "2” 相匹配。 
正则表达式中还有一个较为常用的运算符,即否定符 "[^]”。与我们前文所介绍的定位符 "^” 不同,否定符 "[^]”规定目标对象中不能存在模式中所规定的字符串。例如:/[^A-C]/ 上述字符串将会与目标对象中除A,B,和C之外的任何字符相匹配。一般来说,当"^”出现在 "[]”内时就被视做否定运算符;而当"^”位于"[]”之外,或没有"[]”时,则应当被视做定位符。 
最后,当用户需要在正则表达式的模式中加入元字符,并查找其匹配对象时,可以使用转义符"/”。例如:/Th/*/  上述正则表达式将会与目标对象中的"Th*”而非"The”等相匹配。 
在构造正则表达式之后,就可以象数学表达式一样来求值,也就是说,可以从左至右并按照一个优先级顺序来求值。优先级如下: 
1./ 转义符 
2.(), (?, (?=), [] 圆括号和方括号 
3.*, +, ?, {n}, {n,}, {n,m} 限定符 
4.^, $, /anymetacharacter 位置和顺序 
5.|"或”操作 




使用实例 
在JavaScript 1.2中带有一个功能强大的RegExp()对象,可以用来进行正则表达式的匹配操作。其中的test()方法可以检验目标对象中是否包含匹配模式,并相应的返回true或false。 
我们可以使用JavaScript编写以下脚本,验证用户输入的邮件地址的有效性。 
-------------------------------------------------------- 
 
 
   
   
   
  
 
     
     
   
 
   
 
-------------------------------------------------------- 


正则表达式对象 
本对象包含正则表达式模式以及表明如何应用模式的标志。 
语法 1 re = /pattern/[flags] 
语法 2 re = new RegExp("pattern",["flags"]) 
参数 
re 
必选项。将要赋值为正则表达式模式的变量名。 
Pattern 
必选项。要使用的正则表达式模式。如果使用语法 1,用 "/" 字符分隔模式。如果用语法 2,用引号将模式引起来。 


Flags 
可选项。如果使用语法 2 要用引号将 flag 引起来。标志可以组合使用,可用的有: 
g (全文查找出现的所有 pattern) 
i (忽略大小写) 
m (多行查找) 
示例 
下面的示例创建一个包含正则表达式模式及相关标志的对象(re),向您演示正则表达式对象的用法。在本例中,作为结果的正则表达式对象又用于 match 方法中: 
function MatchDemo() 

var r, re; // 声明变量。 
var s = "The rain in Spain falls mainly in the plain"; 
re = new RegExp("ain","g"); // 创建正则表达式对象。 
r = s.match(re); // 在字符串 s 中查找匹配。 
return(r); 

返回值: ain,ain,ain,ain 
属性 lastIndex 属性 | source 属性 
方法 compile 方法 | exec 方法 | test 方法 
要求 版本 3 
请参阅 RegExp 对象 | 正则表达式语法 | String 对象 


exec 方法 
用正则表达式模式在字符串中运行查找,并返回包含该查找结果的一个数组。 
rgExp.exec(str) 
参数 
rgExp 
必选项。包含正则表达式模式和可用标志的正则表达式对象。 
str 
必选项。要在其中执行查找的 String 对象或字符串文字。 
说明 
如果 exec 方法没有找到匹配,则它返回 null。如果它找到匹配,则 exec 方法返回一个数组,并且更新全局 RegExp 对象的属性,以反映匹配结果。数组的0元素包含了完整的匹配,而第1到n元素中包含的是匹配中出现的任意一个子匹配。这相当于没有设置全局标志 (g) 的 match 方法。 
如果为正则表达式设置了全局标志,exec 从以 lastIndex 的值指示的位置开始查找。如果没有设置全局标志,exec 忽略 lastIndex 的值,从字符串的起始位置开始搜索。 
exec 方法返回的数组有三个属性,分别是 input、index 和 lastIndex。Input 属性包含了整个被查找的字符串。Index 属性中包含了整个被查找字符串中被匹配的子字符串的位置。LastIndex 属性中包含了匹配中最后一个字符的下一个位置。 
示例 
下面的例子举例说明了 exec 方法的用法: 
function RegExpTest() 

var ver = Number(ScriptEngineMajorVersion() + "." + ScriptEngineMinorVersion()) 
if (ver >= 5.5){ // 测试 JScript 的版本。 
var src = "The rain in Spain falls mainly in the plain."; 
var re = //w+/g; // 创建正则表达式模式。 
var arr; 
while ((arr = re.exec(src)) != null) 
document.write(arr.index + "-" + arr.lastIndex + arr + "/t"); 

else{ 
alert("请使用 JScript 的更新版本"); 


返回值:0-3The 4-8rain 9-11in 12-17Spain 18-23falls 24-30mainly 31-33in 34-37the 38-43plain 
test 方法 
返回一个 Boolean 值,它指出在被查找的字符串中是否存在模式。 
rgexp.test(str) 
参数 
rgexp 
必选项。包含正则表达式模式或可用标志的正则表达式对象。 
str 
必选项。要在其上测试查找的字符串。 
说明 
test 方法检查在字符串中是否存在一个模式,如果存在则返回 true,否则就返回 false。 
全局 RegExp 对象的属性不由 test 方法来修改。 
示例 
下面的例子举例说明了 test 方法的用法: 
function TestDemo(re, s) 

var s1; // 声明变量。 
// 检查字符串是否存在正则表达式。 
if (re.test(s)) // 测试是否存在。 
s1 = " contains "; // s 包含模式。 
else 
s1 = " does not contain "; // s 不包含模式。 
return("'" + s + "'" + s1 + "'"+ re.source + "'"); // 返回字符串。 

函数调用:document.write (TestDemo(/ain+/ ,"The rain in Spain falls mainly in the plain.")); 
返回值:'The rain in Spain falls mainly in the plain.' contains 'ain+' 
match 方法 
使用正则表达式模式对字符串执行查找,并将包含查找的结果作为数组返回。 
stringObj.match(rgExp) 
参数 
stringObj 
必选项。对其进行查找的 String 对象或字符串文字。 
rgExp 
必选项。为包含正则表达式模式和可用标志的正则表达式对象。也可以是包含正则表达式模式和可用标志的变量名或字符串文字。 
说明 
如果 match 方法没有找到匹配,返回 null。如果找到匹配返回一个数组并且更新全局 RegExp 对象的属性以反映匹配结果。 
match 方法返回的数组有三个属性:input、index 和 lastIndex。Input 属性包含整个的被查找字符串。Index 属性包含了在整个被查找字符串中匹配的子字符串的位置。LastIndex 属性包含了最后一次匹配中最后一个字符的下一个位置。 
如果没有设置全局标志 (g),数组的 0 元素包含整个匹配,而第 1 到 n 元素包含了匹配中曾出现过的任一个子匹配。这相当于没有设置全局标志的 exec 方法。如果设置了全局标志,元素 0 到 n 中包含所有匹配。 
示例 
下面的示例演示了match 方法的用法: 
function MatchDemo() 

var r, re; // 声明变量。 
var s = "The rain in Spain falls mainly in the plain"; 
re = /ain/i; // 创建正则表达式模式。 
r = s.match(re); // 尝试匹配搜索字符串。 
return(r); // 返回第一次出现 "ain" 的地方。 

返回值:ain 
本示例说明带 g 标志设置的 match 方法的用法。 
function MatchDemo() 

var r, re; // 声明变量。 
var s = "The rain in Spain falls mainly in the plain"; 
re = /ain/ig; // 创建正则表达式模式。 
r = s.match(re); // 尝试去匹配搜索字符串。 
return(r); // 返回的数组包含了所有 "ain" 
// 出现的四个匹配。 

返回值:ain,ain,ain,ain 
上面几行代码演示了字符串文字的 match 方法的用法。 
var r, re = "Spain"; 
r = "The rain in Spain".replace(re, "Canada"); 
return r; 
返回值:The rain in Canada 
search 方法 
返回与正则表达式查找内容匹配的第一个子字符串的位置。 
stringObj.search(rgExp) 
参数 
stringObj 
必选项。要在其上进行查找的 String 对象或字符串文字。 
rgExp 
必选项。包含正则表达式模式和可用标志的正则表达式对象。 
说明 
search 方法指明是否存在相应的匹配。如果找到一个匹配,search 方法将返回一个整数值,指明这个匹配距离字符串开始的偏移位置。如果没有找到匹配,则返回 -1。 
示例 
下面的示例演示了 search 方法的用法。 
function SearchDemo() 

var r, re; // 声明变量。 
var s = "The rain in Spain falls mainly in the plain."; 
re = /falls/i; // 创建正则表达式模式。 
r = s.search(re); // 查找字符串。 
return(r); // 返回 Boolean 结果。 

返回值:18 




正则表达式语法 
一个正则表达式就是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式。该模式描述在查找文字主体时待匹配的一个或多个字符串。正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配。 


这里有一些可能会遇到的正则表达式示例: 


JScript VBScript 匹配 
/^/[ /t]*$/ "^/[ /t]*$" 匹配一个空白行。 
//d{2}-/d{5}/ "/d{2}-/d{5}" 验证一个ID 号码是否由一个2位数字,一个连字符以及一个5位数字组成。 
/<(.*)>.*/ "<(.*)>.*" 匹配一个 HTML 标记。 




下表是元字符及其在正则表达式上下文中的行为的一个完整列表: 


字符 描述 
/ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个 后向引用、或一个八进制转义符。例如,'n' 匹配字符 "n"。'/n' 匹配一个换行符。序列 '//' 匹配 "/" 而 "/(" 则匹配 "("。 
^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 '/n' 或 '/r' 之后的位置。 
$ 匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 '/n' 或 '/r' 之前的位置。 
* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。 * 等价于{0,}。 
+ 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。 
? 匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等价于 {0,1}。 
{n} n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。 
{n,} n 是一个非负整数。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。 
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。刘, "o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。 
? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个 "o",而 'o+' 将匹配所有 'o'。 
. 匹配除 "/n" 之外的任何单个字符。要匹配包括 '/n' 在内的任何字符,请使用象 '[./n]' 的模式。 
(pattern) 匹配pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 $0…$9 属性。要匹配圆括号字符,请使用 '/(' 或 '/)'。 
(?:pattern) 匹配 pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。这在使用 "或" 字符 (|) 来组合一个模式的各个部分是很有用。例如, 'industr(?:y|ies) 就是一个比 'industry|industries' 更简略的表达式。 
(?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如, 'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。 
(?!pattern) 负向预查,在任何不匹配Negative lookahead matches the search string at any point where a string not matching pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始 
x|y 匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 则匹配 "zood" 或 "food"。 
[xyz] 字符集合。匹配所包含的任意一个字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'。 
[^xyz] 负值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'。 
[a-z] 字符范围。匹配指定范围内的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范围内的任意小写字母字符。 
[^a-z] 负值字符范围。匹配任何不在指定范围内的任意字符。例如,'[^a-z]' 可以匹配任何不在 'a' 到 'z' 范围内的任意字符。 
/b 匹配一个单词边界,也就是指单词和空格间的位置。例如, 'er/b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。 
/B 匹配非单词边界。'er/B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。 
/cx 匹配由x指明的控制字符。例如, /cM 匹配一个 Control-M 或回车符。 x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一个原义的 'c' 字符。 
/d 匹配一个数字字符。等价于 [0-9]。 
/D 匹配一个非数字字符。等价于 [^0-9]。 
/f 匹配一个换页符。等价于 /x0c 和 /cL。 
/n 匹配一个换行符。等价于 /x0a 和 /cJ。 
/r 匹配一个回车符。等价于 /x0d 和 /cM。 
/s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ /f/n/r/t/v]。 
/S 匹配任何非空白字符。等价于 [^ /f/n/r/t/v]。 
/t 匹配一个制表符。等价于 /x09 和 /cI。 
/v 匹配一个垂直制表符。等价于 /x0b 和 /cK。 
/w 匹配包括下划线的任何单词字符。等价于'[A-Za-z0-9_]'。 
/W 匹配任何非单词字符。等价于 '[^A-Za-z0-9_]'。 
/xn 匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。例如, '/x41' 匹配 "A"。'/x041' 则等价于 '/x04' & "1"。正则表达式中可以使用 ASCII 编码。. 
/num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。例如,'(.)/1' 匹配两个连续的相同字符。 
/n 标识一个八进制转义值或一个后向引用。如果 /n 之前至少 n 个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。 
/nm 标识一个八进制转义值或一个后向引用。如果 /nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 /nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 /nm 将匹配八进制转义值 nm。 
/nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八进制转义值 nml。 
/un 匹配 n,其中 n 是一个用四个十六进制数字表示的 Unicode 字符。例如, /u00A9 匹配版权符号 (?)。 




优先权顺序 
在构造正则表达式之后,就可以象数学表达式一样来求值,也就是说,可以从左至右并按照一个优先权顺序来求值。 


下表从最高优先级到最低优先级列出各种正则表达式操作符的优先权顺序: 


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




普通字符 
普通字符由所有那些未显式指定为元字符的打印和非打印字符组成。这包括所有的大写和小写字母字符,所有数字,所有标点符号以及一些符号。 


最简单的正则表达式是一个单独的普通字符,可以匹配所搜索字符串中的该字符本身。例如,单字符模式 'A' 可以匹配所搜索字符串中任何位置出现的字母 'A'。这里有一些单字符正则表达式模式的示例: 


/a/ 
/7/ 
/M/ 
等价的 VBScript 单字符正则表达式为: 


"a" 
"7" 
"M" 
可以将多个单字符组合在一起得到一个较大的表达式。例如,下面的 JScript 正则表达式不是别的,就是通过组合单字符表达式 'a'、'7'以及 'M' 所创建出来的一个表达式。 


/a7M/ 
等价的 VBScript 表达式为: 


"a7M" 
请注意这里没有连接操作符。所需要做的就是将一个字符放在了另一个字符后面。 






( 2006年03月02日, 04:51:37 下午 CST / 2006年03月02日, 04:47:58 下午 CST Permalink 留言 [0] 
Trackback: http://blog.matrix.org.cn/trackback/pawenwen/Weblog/js%E7%9A%84%E6%AD%A3%E5%88%99%E8%A1%A8%E8%BE%BE%E5%BC%8F




星期三 2005年12月14日 


ajax上手 
第一步 – 說聲「請」 (又稱為「怎麼發出 XMLHttpRequest」) 
為了用 JavaScript 對伺服器發送 HTTP 要求,你必須先以相關的類別(class)製出實體(instance)。Internet Explorer 首先以 ActiveX 物件方式提供 XMLHTTP 類別,而 Mozilla、Safari 及其他瀏覽器則隨後以 XMLHttpRequest 類別支援此 ActiveX 物件中的類別及屬性。 
因此,如果想跨瀏覽器,那麼可以這麼寫: 
if (window.XMLHttpRequest) { // Mozilla, Safari, ... 
http_request = new XMLHttpRequest(); 
} else if (window.ActiveXObject) { // IE 
http_request = new ActiveXObject("Microsoft.XMLHTTP"); 

(由於這段程式僅供說明,所以是採最簡方式寫出。本文第三步中有另一種我們比較常用的寫法。) 
有些版本的 Mozilla 瀏覽器在伺服器送回的資料未含 XML mime-type 檔頭(header)時會出錯。為了避免這個問題,你可以用下列方法覆寫伺服器傳回的檔頭,以免傳回的不是 text/xml。 
http_request = new XMLHttpRequest(); 
http_request.overrideMimeType('text/xml'); 
接下來是要決定伺服器傳回資料後的處理方式,此時你只要以 onreadystatechange 這個屬性指明要處理傳回值的 JavaScript 函式名稱即可,例如: 
http_request.onreadystatechange = nameOfTheFunction; 
注意,指定的函式名稱後不加括號也沒有參數。除了指定函式名稱外,你也能用 Javascript 即時定義函式的方法來定一個新的處理函式,如下: 
http_request.onreadystatechange = function(){ 
// 做些事 
}; 
決定處理方式之後你得確實發出 request,此時需叫用 HTTP request 類別的 open() 及 send() 方法,如下: 
http_request.open('GET', 'http://www.example.org/some.file', true); 
http_request.send(null); 
open() 的第一個參數是 HTTP request 的方法,也就是從 GET、POST、HEAD 中擇一使用,亦可用你主機上支援的方式。為遵循 HTTP 標準,請記得這些方法都是大寫,不然有的瀏覽器(如 Firefox)或許不會理你。其他 HTTP request 可以支援的方法列表請參考 W3C 規格書 (http://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html)。 
第二個參數是目標 URL。基於安全考量,你不能叫用同網域以外的網頁。如果網域不同,則叫用 open() 時會出現「權限不足,拒絕存取」那類的錯誤。通常大夥會犯的錯誤多為在 domain.tld 網的網站下呼叫 www.domain.tld 中的網頁,僅是一點點差別都不行。 
第三個參數決定此 request 是否不同步進行,如果設定為 TRUE 則即使伺服器尚未傳回資料也會繼續執行其餘的程式,這也就是 AJAX 中第一個 A 代表的意義。 
send() 的參數在以 POST 發出 request 時可以是任何想傳給伺服器的東西,而資料則以查詢字串的方式列出,例如: 
name=value&anothername=othervalue&so=on 
不過如果你想要以 POST 方式傳送資料,則必須先將 MIME 型態改好,如下: 
http_request.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); 否則伺服器就不會理你傳過來的資料了。 
[編輯]第二步 – 「就上咩!」(又稱為「處理伺服器傳回的資料」) 
傳出 request 時必須提供處理傳回值的函式名稱。 
http_request.onreadystatechange = nameOfTheFunction; 
那麼來看看這個函式該做些什麼。首先,它必須檢查 request 目前的狀態:如果狀態值為 4 代表伺服器已經傳回所有資訊了,便可以開始解析所得資訊。 
if (http_request.readyState == 4) { 
// 一切 ok, 繼續解析 
} else { 
// 還沒完成 

readyState 所有可能的值如下: 
0 (還沒開始) 
1 (讀取中) 
2 (已讀取) 
3 (資訊交換中) 
4 (一切完成) 
(資料來源: MSDN (http://msdn.microsoft.com/workshop/author/dhtml/reference/properties/readystate_1.asp)) 
接下來要檢查伺服器傳回的 HTTP 狀態碼。所有狀態碼列表可於 W3C 網站 (http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html)上查到,但我們要管的是 200 OK 這種狀態。 
if (http_request.status == 200) { 
// 萬事具備 
} else { 
// 似乎有點問題,或許伺服器傳回了 404 (查無此頁) 或者 500 (內部錯誤) 什麼的 

檢查傳回的 HTTP 狀態碼後,要怎麼處理傳回的資料就由你決定了。有兩種存取資料的方式: 
http_request.responseText – 這樣會把傳回值當字串用 
http_request.responseXML – 這樣會把傳回值視為 XMLDocument 物件,而後可用 JavaScript DOM 相關函式處理
[編輯]第三步 - 萬事俱備 - 簡單範例 
好,接著就做一次簡單的 HTTP 範例,演示方才的各項技巧。這段 JavaScript 會向伺服器要一份裡頭有「I'm a test.」字樣的 HTML 文件(test.html),而後以 alert() 將文件內容列出。 
 
style="cursor: pointer; text-decoration: underline" 
οnclick="makeRequest('test.html')"> 
Make a request 
 
在此範例中: 
首先使用者按下「Make a request」 
這麼一來就會呼叫 makeRequest() 函式,亦傳入參數值 test.html (也就是那份 HTML 檔的名稱,放在同目錄下) 
接著發出 request,而後會將主導權交給 onreadystatechange 指定的 alertContents() 函式 alertContents() 檢查回應是否正常,而後以 alert() 將 test.html 的內容列出 你可以由此測試本例 (http://www.w3clubs.com/mozdev/httprequest_test.html),也可以參考測試檔案 (http://www.w3clubs.com/mozdev/test.html)。 
[編輯]第四步 – 「X 檔案」(又稱為「處理 XML 回應值」) 前面的例子中,在收到 HTTP 傳回值後我們以物件的 reponseText 屬性使用 test.html 檔案的內容,接著來試試 responseXML 屬性的方法。 
首先,我們得做個格式正確的 XML 文件,以便稍後取用。此檔名喚 test.xml,內容如下: 
 
 
I'm a test. 
 
在程式中,我們叫用檔案的地方只須略事修改如下: 
... οnclick="makeRequest('test.xml')"> 
... 接著在 alertContents() 中,我們必須將 alert(http_request.responseText); 改成這樣: 
var xmldoc = http_request.responseXML; 
var root_node = xmldoc.getElementsByTagName('root').item(0); 
alert(root_node.firstChild.data); 
這樣一來我們便可取得 responseXML 所傳回的 XMLDocument 物件,而後以 DOM 相關的方法取用 XML 文件內容。你可以參考 test.xml 的原始碼 (http://www.w3clubs.com/mozdev/test.xml) 以及修改過後的測試程式 (http://www.w3clubs.com/mozdev/httprequest_test_xml.html)。 
其他與 DOM 相關的方法,請參考 Mozilla DOM (http://www.mozilla.org/docs/dom/) 文件。 




( 2005年12月14日, 11:14:54 上午 CST / 2005年12月14日, 11:14:54 上午 CST Permalink 留言 [0] 
Trackback: http://blog.matrix.org.cn/trackback/pawenwen/Weblog/ajax%E4%B8%8A%E6%89%8B 




星期五 2005年11月25日 


web开发的下一个学习方向:ajax 
最近一直在折腾ajax这个概念。折腾来折腾去,觉得这个东西还是蛮有吸引力的,虽然不是什么新鲜概念,但是如果有人打算将来一直做web开发,那现在就有必要开始研究一下这个东西了,google的gmail/maps/sns/groups..好多的东西都是寄予ajax framework的实现。 
什么是ajax: http://www.baidu.com/s?wd=%CA%B2%C3%B4%CA%C7ajax&cl=3 http://www.google.com/search?hl=zh-CN&newwindow=1&q=%E4%BB%80%E4%B9%88%E6%98%AFajax&lr= 


介绍ajax设计模式的网站:www.ajaxpatterns.org 


进行ajax开发应用,对"css/javascript/dom”的要求比较高,所以进行开发前,最好要先提高一下对"css/javascript/dom”了解。 
一个很好的学习html/css/wml/javascript/dom/xml/xlt.........的地方: 
http://www.w3schools.com/ 




================================================================== 
今天在看《ajax in action》进度比较慢,才看了三章,下面是一些书里提到的ajax的实现基础和框架。 




下面是一些兼容不同的浏览器的一些javascirpt的lib库,可以帮你忽略一些不同浏览器的javascript不兼容的问题: 
x library: http://cross-browser.com/ 
Sarissa: http://sarissa.sourceforge.net/doc/ 
Prototype: http://prototype.conio.net/(http://www.javaeye.com/viewtopic.php?t=14347) 




three small client-side frameworks:实现非常简单,通过javascript和xmlhttp实现ajax,与server端语言没有任何关系。 
Prototype: http://prototype.conio.net/ 
Scriptaculous: http://script.aculo.us/ 
Rico: http://openrico.org/rico/home.page 




three small server-side frameworks: 自动生成server端的function和object的Javascript存根,简洁的测试页面,远程调用Javascript的安全性,自动转换数据类型。web页面通过调用javascript存根,来访问相应的server端的function和object。 
DWR:http://getahead.ltd.uk/dwr 
JSON-RPC:http://json-rpc.org/ 
SAJAX:http://www.modernmethod.com/sajax/ (支持php) 




three complex server-side frameworks: 允许你用纯Java等server端语言来代码编写Ajax应用软件,他们提供web页面的代码的封装,依赖性比较强,每个的实现差别比较大,速度可能会有问题(echo2感觉就比较慢)。 
Backbase: http://www.backbase.com 
Echo2: http://www.nextapp.com/products/echo2/ 
Ruby on Rails: http://www.rubyonrails.org/ 


Ruby on Rails最新版包含ajax功能,前面提到的Prototype就是从这个里面分离出去的 




( 2005年11月29日, 04:24:05 下午 CST / 2005年11月25日, 12:58:43 下午 CST Permalink 留言 [1] 
Trackback: http://blog.matrix.org.cn/trackback/pawenwen/Weblog/web%E5%BC%80%E5%8F%91%E7%9A%84%E4%B8%8B%E4%B8%80%E4%B8%AA%E5%AD%A6%E4%B9%A0%E6%96%B9%E5%90%91_ajax




Ajax:"世说新语” 
当前最热门的Web技术是什么?很明显,Ajax已经成为不可忽视的词语,趁着Web2.0浪潮的到来,Ajax也愈发的受到了人们的关注,带来的是更为强大的Web体验和对桌面软件的威胁。本期专题将对该技术做一次亲密接触。希望大家能有所体会。 
要准确描述什么是Ajax,最容易的方法是让其与相反的情况进行对比。对于大部分Web站点,与Web服务器进行交互是最简单的通信方式——就如您在对讲机(walkie-talkie)上与好友聊天一样。您可以一边讲话他在另一边接听,或者他说话你接听,但您不能同时接听和讲话。对于Web用户,当填写在线表单然后单击提交按钮后,整个页面就会发送至Web服务器,用户必须等待服务器接受请受。当服务器完成处理请求时,它就会将处理过的内容发送过来。只有这时,才可以最终刷新用户页面。Ajax是一种减少这一系列事件的尝试。当用户位于Ajax类型的Web站点时,浏览器可以幕后异步调用Web服务器而无需发送整个页面。 
应该注意Ajax并非新生事物。该方法论已运用了好多年。Web站点(如Google)正在证明Ajax的有效性、稳定性,并且使Web看起来更像是一个桌面应用程序:即真正意义的Web开发。Ajax特殊之处在于它可以使用验证过的现有技术完成这一切。换句话说就是,任何标准浏览器(可以处理JavaScript和DOM的浏览器)都可以正常工作。您不需要单独安装其他插件。 
Ajax实际上是几项技术, 每个都本身之能力而发展, 组合在一起形成了一个更强的新方法。Ajax组合了: 
·使用XHTML和CSS的standards-based presentation; 
·使用Document Object Model 来动态显示和交互作用; 
·使用XML and XSLT 来数据交换和操作; 
·使用XMLHttpRequest来获取异步信息; 
·使用JavaScript 将所有的联系起来。 
在创建Ajax中最大的挑战不是技术。核心Ajax 技术是成熟的, 稳定的, 并且易于了解。反而, 挑战来自应用的设计人员:忘记那些我们所知道关于Web的限制, 并且开始想象一个可能更宽, 更广的范围。前景将更美好。










在b/s开发中经常用到的javaScript技术 
一、验证类 
1、数字验证内 
1.1 整数 
1.2 大于0的整数 (用于传来的ID的验证) 
1.3 负整数的验证 
1.4 整数不能大于iMax 
1.5 整数不能小于iMin 
2、时间类 
2.1 短时间,形如 (13:04:06) 
2.2 短日期,形如 (2003-12-05) 
2.3 长时间,形如 (2003-12-05 13:04:06) 
2.4 只有年和月。形如(2003-05,或者2003-5) 
2.5 只有小时和分钟,形如(12:03) 
3、表单类 
3.1 所有的表单的值都不能为空 
3.2 多行文本框的值不能为空。 
3.3 多行文本框的值不能超过sMaxStrleng 
3.4 多行文本框的值不能少于sMixStrleng 
3.5 判断单选框是否选择。 
3.6 判断复选框是否选择. 
3.7 复选框的全选,多选,全不选,反选 
3.8 文件上传过程中判断文件类型 
4、字符类 
4.1 判断字符全部由a-Z或者是A-Z的字字母组成 
4.2 判断字符由字母和数字组成。 
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母 
4.4 字符串替换函数.Replace(); 
5、浏览器类 
5.1 判断浏览器的类型 
5.2 判断ie的版本 
5.3 判断客户端的分辨率 


6、结合类 
6.1 email的判断。 
6.2 手机号码的验证 
6.3 身份证的验证 




二、功能类 


1、时间与相关控件类 
1.1 日历 
1.2 时间控件 
1.3 万年历 
1.4 显示动态显示时钟效果(文本,如OA中时间) 
1.5 显示动态显示时钟效果 (图像,像手表) 
2、表单类 
2.1 自动生成表单 
2.2 动态添加,修改,删除下拉框中的元素 
2.3 可以输入内容的下拉框 
2.4 多行文本框中只能输入iMax文字。如果多输入了,自动减少到iMax个文字(多用于短信发送) 


3、打印类 
3.1 打印控件 
4、事件类 
4.1 屏蔽右键 
4.2 屏蔽所有功能键 
4.3 --> 和<-- F5 F11,F9,F1 
4.4 屏蔽组合键ctrl+N 
5、网页设计类 
5.1 连续滚动的文字,图片(注意是连续的,两段文字和图片中没有空白出现) 
5.2 html编辑控件类 
5.3 颜色选取框控件 
5.4 下拉菜单 
5.5 两层或多层次的下拉菜单 
5.6 仿IE菜单的按钮。(效果如rongshuxa.com的导航栏目) 
5.7 状态栏,title栏的动态效果(例子很多,可以研究一下) 
5.8 双击后,网页自动滚屏 
6、树型结构。 
6.1 asp+SQL版 
6.2 asp+xml+sql版 
6.3 java+sql或者java+sql+xml 
7、无边框效果的制作 
8、连动下拉框技术 
9、文本排序 




一、验证类 
1、数字验证内 
1.1 整数 
/^(-|/+)?/d+$/.test(str) 
1.2 大于0的整数 (用于传来的ID的验证) 
/^/d+$/.test(str) 
1.3 负整数的验证 
/^-/d+$/.test(str) 
2、时间类 
2.1 短时间,形如 (13:04:06) 
function isTime(str) 

var a = str.match(/^(/d{1,2})(:)?(/d{1,2})/2(/d{1,2})$/); 
if (a == null) {alert('输入的参数不是时间格式'); return false;} 
if (a[1]>24 || a[3]>60 || a[4]>60) 

alert("时间格式不对"); 
return false 

return true; 

2.2 短日期,形如 (2003-12-05) 
function strDateTime(str) 

var r = str.match(/^(/d{1,4})(-|//)(/d{1,2})/2(/d{1,2})$/); 
if(r==null)return false; 
var d= new Date(r[1], r[3]-1, r[4]); 
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]); 

2.3 长时间,形如 (2003-12-05 13:04:06) 
function strDateTime(str) 

var reg = /^(/d{1,4})(-|//)(/d{1,2})/2(/d{1,2}) (/d{1,2}):(/d{1,2}):(/d{1,2})$/; 
var r = str.match(reg); 
if(r==null)return false; 
var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]); 
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);

2.4 只有年和月。形如(2003-05,或者2003-5) 
2.5 只有小时和分钟,形如(12:03) 
3、表单类 
3.1 所有的表单的值都不能为空 
 
3.2 多行文本框的值不能为空。 
3.3 多行文本框的值不能超过sMaxStrleng 
3.4 多行文本框的值不能少于sMixStrleng 
3.5 判断单选框是否选择。 
3.6 判断复选框是否选择. 
3.7 复选框的全选,多选,全不选,反选 
3.8 文件上传过程中判断文件类型 
4、字符类 
4.1 判断字符全部由a-Z或者是A-Z的字字母组成 
 
4.2 判断字符由字母和数字组成。 
 
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母 
/^([a-zA-z_]{1})([/w]*)$/g.test(str) 
4.4 字符串替换函数.Replace(); 
5、浏览器类 
5.1 判断浏览器的类型 
window.navigator.appName 
5.2 判断ie的版本 
window.navigator.appVersion 
5.3 判断客户端的分辨率 
window.screen.height; window.screen.width; 


6、结合类 
6.1 email的判断。 
function ismail(mail) 

return(new RegExp(/^/w+((-/w+)|(/./w+))*/@[A-Za-z0-9]+((/.|-)[A-Za-z0-9]+)*/.[A-Za-z0-9]+$/).test(mail)); 

6.2 手机号码的验证 
6.3 身份证的验证 
function isIdCardNo(num) 

if (isNaN(num)) {alert("输入的不是数字!"); return false;} 
var len = num.length, re; 
if (len == 15) 
re = new RegExp(/^(/d{6})()?(/d{2})(/d{2})(/d{2})(/d{3})$/); 
else if (len == 18) 
re = new RegExp(/^(/d{6})()?(/d{4})(/d{2})(/d{2})(/d{3})(/d)$/); 
else {alert("输入的数字位数不对!"); return false;} 
var a = num.match(re); 
if (a != null) 

if (len==15) 

var D = new Date("19"+a[3]+"/"+a[4]+"/"+a[5]); 
var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5]; 

else 

var D = new Date(a[3]+"/"+a[4]+"/"+a[5]); 
var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5]; 

if (!B) {alert("输入的身份证号 "+ a[0] +" 里出生日期不对!"); return false;} 

return true; 



3.7 复选框的全选,多选,全不选,反选 
 
全选
 

 

 

 

 


 




全选
 

 

 

 

 

 


 


 


3.8 文件上传过程中判断文件类型 
 


画图: 
id=S 
style="LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px" 
height=240 
width=392 
classid="clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6"> 
 
 


写注册表: 
 


TABLAE相关(客户端动态增加行列) 
 
 
 
 
 
 
 
 
 
 


1.身份证严格验证: 


 


2.验证IP地址 
 






3.加sp1后还能用的无边框窗口!! 
 
 
 
Chromeless Window 


 
 


电话号码的验证 


要求: 
  (1)电话号码由数字、"("、")"和"-"构成 
  (2)电话号码为3到8位 
  (3)如果电话号码中包含有区号,那么区号为三位或四位 
  (4)区号用"("、")"或"-"和其他部分隔开 
  (5)移动电话号码为11或12位,如果为12位,那么第一位为0 
  (6)11位移动电话号码的第一位和第二位为"13" 
  (7)12位移动电话号码的第二位和第三位为"13" 
  根据这几条规则,可以与出以下正则表达式: 
  (^[0-9]{3,4}/-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^/([0-9]{3,4}/)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$) 




 
 
 


具有在输入非数字字符不回显的效果,即对非数字字符的输入不作反应。 
function numbersonly(field,event){ 
var key,keychar; 
if(window.event){ 
key = window.event.keyCode; 

else if (event){ 
key = event.which; 

else{ 
return true 

keychar = String.fromCharCode(key); 
if((key == null)||(key == 0)||(key == 8)||(key == 9)||(key == 13)||(key == 27)){ 
return true; 

else if(("0123456789.").indexOf(keychar)>-1){ 
window.status = ""; 
return true; 

else { 
window.status = "Field excepts numbers only"; 
return false; 




验证ip 


str=document.RegExpDemo.txtIP.value; 
if(/^(/d{1,3})/.(/d{1,3})/.(/d{1,3})/.(/d{1,3})$/.test(str)==false) 

window.alert('错误的IP地址格式'); 
document.RegExpDemo.txtIP.select(); 
document.RegExpDemo.txtIP.focus(); 
return; 

if(RegExp.$1<1 || RegExp.$1>254||RegExp.$2<0||RegExp.$2>254||RegExp.$3<0||RegExp.$3>254||RegExp.$4<1||RegExp.$4>254)

window.alert('错误的IP地址'); 
document.RegExpDemo.txtIP.select(); 
document.RegExpDemo.txtIP.focus(); 
return; 

//剔除 如 010.020.020.03 前面 的0 
var str=str.replace(/0(/d)/g,"$1"); 
str=str.replace(/0(/d)/g,"$1"); 
window.alert(str); 




//一下是取数据的类 
//Obj参数指定数据的来源(限定Table),默认第一行为字段名称行 
//GetTableData类提供MoveNext方法,参数是表的行向上或向下移动的位数,正数向下移动,负数向上. 
//GetFieldData方法获得指定的列名的数据 
//Sort_desc方法对指定的列按降序排列 
//Sort_asc方法对指定的列按升序排列 
//GetData方法返回字段值为特定值的数据数组,提供数据,可以在外部进行其他处理 
//Delete方法删除当前记录,数组减少一行 
//初始化,Obj:table的名字,Leftlen:左面多余数据长度,Rightlen:右面多余数据长度, 
function GetTableData(Obj,LeftLen,RightLen){ 
var MyObj=document.all(Obj); 
var iRow=MyObj.rows.length; 
var iLen=MyObj.rows[0].cells.length; 
var i,j; 


TableData=new Array(); 
for (i=0;i< iRow;i++){ 
TableData[i]=new Array(); 
for (j=0;j TableStr=MyObj.rows(i).cells(j).innerText; 
TableStr=TableStr.substring(LeftLen, TableStr.length-RightLen).Trim(); 
TableStr=TableStr.replace(/ /gi,"").replace(//r/n/ig,""); 
TableData[i][j]=TableStr; 




this.TableData=TableData; 
this.cols=this.TableData[0].length; 
this.rows=this.TableData.length; 
this.rowindex=0; 





function movenext(Step){ 
if (this.rowindex>=this.rows){ 
return 



if (Step=="" || typeof(Step)=="undefined") { 
if (this.rowindex this.rowindex++; 
return; 



else{ 
if (this.rowindex + Step<=this.rows-1 && this.rowindex + Step>=0 ){ 
this.rowindex=this.rowindex + Step; 

else 

if (this.rowindex + Step<0){ 
this.rowindex= 0; 
return; 

if (this.rowindex + Step>this.rows-1){ 
this.rowindex= this.rows-1; 
return; 








function getfielddata(Field){ 
var colindex=-1; 
var i=0; 
if (typeof(Field) == "number"){ 
colindex=Field; 

else 

for (i=0;i if (this.TableData[0][i]==Field){ 
colindex=i; 
break; 



if (colindex!=-1) { 
return this.TableData[this.rowindex][colindex]; 










function sort_desc(){//降序 
var colindex=-1; 
var highindex=-1; 
desc_array=new Array(); 
var i,j; 
for (n=0; n Field=arguments[arguments.length-1-n]; 
for (i=0;i if (this.TableData[0][i]==Field){ 
colindex=i; 
break; 


if ( colindex==-1 ) 
return; 
else 

desc_array[0]=this.TableData[0]; 
for(i=1;i desc_array[i]=this.TableData[1]; 
highindex=1; 
for(j=1;j if (desc_array[i][colindex] desc_array[i]=this.TableData[j]; 
highindex=j; 




if (highindex!=-1) 
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));






this.TableData=desc_array; 

return; 







function sort_asc(){//升序 
var colindex=-1; 
var highindex=-1; 
var i,j; 
for (n=0; n asc_array=new Array(); 
Field=arguments[arguments.length-1-n]; 
for (i=0;i if (this.TableData[0][i]==Field){ 
colindex=i; 
break; 


if ( colindex==-1 ) 
return; 
else 

asc_array[0]=this.TableData[0]; 
for(i=1;i asc_array[i]=this.TableData[1]; 
highindex=1; 
for(j=1;j if (asc_array[i][colindex]>this.TableData[j][colindex]){ 
asc_array[i]=this.TableData[j]; 
highindex=j; 






if (highindex!=-1) 
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));








this.TableData=asc_array; 

return; 







function getData(Field,FieldValue){ 
var colindex=-1; 
var i,j; 


GetData=new Array(); 
if (typeof(Field)=="undefined" || typeof(FieldValue)=="undefined" ){ 
return this.TableData; 



for(j=0;j if (this.TableData[0][j]==Field){ 
colindex=j; 


if (colindex!=-1){ 


for(i=1;i if (this.TableData[i][colindex]==FieldValue){ 
GetData[i]=new Array(); 
GetData[i]=this.TableData[i]; 



return GetData; 

function DeletE(){ 
this.TableData=this.TableData.slice(0,this.rowindex).concat(this.TableData.slice(this.rowindex+1,this.TableData.length));
this.rows=this.TableData.length; 
return; 

function updateField(Field,FieldValue){ 
var colindex=-1; 
var i=0; 
if (typeof(Field) == "number"){ 
colindex=Field; 

else 

for (i=0;i if (this.TableData[0][i]==Field){ 
colindex=i; 
break; 



if (colindex!=-1) { 
this.TableData[this.rowindex][colindex]=FieldValue; 






function movefirst(){ 
this.rowindex=0; 

function movelast(){ 
this.rowindex=this.rows-1; 

function String.prototype.Trim() {return this.replace(/(^/s*)|(/s*$)/g,"");} 
GetTableData.prototype.MoveNext = movenext; 
GetTableData.prototype.GetFieldData = getfielddata; 
GetTableData.prototype.Sort_asc = sort_asc; 
GetTableData.prototype.Sort_desc = sort_desc; 
GetTableData.prototype.GetData = getData; 
GetTableData.prototype.Delete = DeletE; 
GetTableData.prototype.UpdateField = updateField; 
GetTableData.prototype.MoveFirst = movefirst; 


具体的例子:http://202.119.73.208/NetEAn/com/test/jsprint.htm 


在每个文本框的onblur事件中调用校验代码,并且每个文本框中onKeyDown事件中写一个enter转tab函数 


//回车键换为tab 
function enterToTab() 

if(event.srcElement.type != 'button' && event.srcElement.type != 'textarea' 
&& event.keyCode == 13) 

event.keyCode = 9; 




有时候还需要自由编辑表格--- 
给大家一个自由编辑表格的小例子,写的有点乱,呵呵:) 


//===============================start================================ 




 
 
 
测试修改表格 
 
 
 
 


 
οnclick="editerTableCell('editer_table','no_editer')"> 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
自由编辑表格
单击开始编辑按钮,然后点击各单元格编辑 2 3
4 5 6
one two three
four five six
 
 
 
 
请单击某个单元格进行编辑!
 

你可能感兴趣的:(js 正则表达式)