首页 > 编程 > Regex > 正文

Javascript正则表达式测试网页

2020-03-16 21:24:11
字体:
来源:转载
供稿:网友

你平时如何测试正则表达式?直接写在大段的代码中,然后等待程序运行到那里,再用alert显示结果?或者是临时写一个页面,测试完成后把它丢掉? 



你可以试一下我这个页面,虽然它很粗糙,但是测试正则表达式也足够了:)) 



一、说明: 

1. 我的本意为交流技术.本人水平很菜.因此所贴出的代码中,会有不足之处. 

2. 代码可任意修改.如果你觉得你修改过的代码比我的好,可将它贴出,我非常感谢. 

3. 我对javascript的规范并不很熟悉.我的经验来自于开发.因此,若你对它有更好的见解,欢迎提出,我非常感谢. 



二、测试用例: 



1. 检查字符串中是否有非数字的字符: 

test regex: /D 

test regex flags: g 

test string: 1234g56t78 



2. 检查字符串中是否有非0-9、a~z、A-Z、_的字符: 

test regex: /W 

test regex flags: g 

test string: i'm a pig! yes I'm! 



3. 匹配字符串中的实数: 



test regex: ([/d]+])/.([/d]+) 

test regex flags: g 

test string: float1234.58.723c65.183 



三、程序代码: 



 

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  2.  
  3. <HTML>  
  4.  
  5. <HEAD>  
  6.  
  7. <TITLE>Javascript regex test page</TITLE>  
  8.  
  9. <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=GB2312">  
  10.  
  11. <SCRIPT>  
  12.  
  13. /**  
  14.  
  15. * Method 测试正则表达式函数  
  16.  
  17. * @param method 接收到的正则表达式类的方法  
  18.  
  19. */  
  20.  
  21. function check(method)  
  22.  
  23. {  
  24.  
  25. // 将用户输入的正则表达式的标志转换为小写  
  26.  
  27. form1form1.flags.value = form1.flags.value.toLowerCase();  
  28.  
  29.  
  30.  
  31. // 如果含有不是g、i、m的字符, 则 提示并返回  
  32.  
  33. if ( form1.flags.value.search(/[^g|i|m]/g) != -1 )  
  34.  
  35. {  
  36.  
  37. alert("flags only can be g, i, m");  
  38.  
  39. return;  
  40.  
  41. }  
  42.  
  43.  
  44.  
  45. // 利用用户输入的字符串和标志建立正则表达式  
  46.  
  47. var re = new RegExp(form1.regex.value, form1.flags.value);  
  48.  
  49.  
  50.  
  51. // 获得并显示生成的正则表达式的字符串形式  
  52.  
  53. destRegex.innerText = re.toString() + ' ';  
  54.  
  55.  
  56.  
  57. // 定义 返回值  
  58.  
  59. var cr;  
  60.  
  61.  
  62.  
  63. ex = "new RegExp('" + form1.regex.value + "', '" + form1.flags.value + "').";  
  64.  
  65.  
  66.  
  67. // 根据用户选择的方法, 进行相应的调用  
  68.  
  69. switch ( method )  
  70.  
  71. {  
  72.  
  73. case '0': // 正则表达式的 exec 方法  
  74.  
  75. cr = re.exec(form1.string.value);  
  76.  
  77. exex = ex + "exec('" + form1.string.value + "')";  
  78.  
  79. break;  
  80.  
  81.  
  82.  
  83. case '1': // 正则表达式的 test 方法  
  84.  
  85. cr = re.test(form1.string.value);  
  86.  
  87. exex = ex + "test('" + form1.string.value + "')";  
  88.  
  89. break;  
  90.  
  91.  
  92.  
  93. case '2': // 字符串类的 match 方法  
  94.  
  95. cr = form1.string.value.match(re);  
  96.  
  97. ex = "'" + form1.string.value + "'.match(" + re.toString() + ")";  
  98.  
  99. break;  
  100.  
  101.  
  102.  
  103. case '3': // 字符串类的 search 方法  
  104.  
  105. cr = form1.string.value.search(re);  
  106.  
  107. ex = "'" + form1.string.value + "'.search(" + re.toString() + ")";  
  108.  
  109. break;  
  110.  
  111.  
  112.  
  113. case '4': // 字符串类的 replace 方法  
  114.  
  115. cr = form1.string.value.replace(re);  
  116.  
  117. ex = "'" + form1.string.value + "'.replace(" + re.toString() + ")";  
  118.  
  119. break;  
  120.  
  121.  
  122.  
  123. case '5': // 字符串类的 split 方法  
  124.  
  125. cr = form1.string.value.split(re);  
  126.  
  127. ex = "'" + form1.string.value + "'.split(" + re.toString() + ")";  
  128.  
  129. break;  
  130.  
  131. }  
  132.  
  133.  
  134.  
  135. // 获得并显示表达式  
  136.  
  137. exexpression.innerText = ex;  
  138.  
  139.  
  140.  
  141. // 获得并显示计算结果的类型  
  142.  
  143. returnType.innerText = typeof(cr);  
  144.  
  145.  
  146.  
  147. // 定义结果  
  148.  
  149. var result = '';  
  150.  
  151.  
  152.  
  153. if ( cr != null && typeof(cr) == 'object' && cr.length != null ) // 如果计算结果是一个数组, 则取出所有数组的值  
  154.  
  155. {  
  156.  
  157. for ( i = 0; i < cr.length; i++ )  
  158.  
  159. {  
  160.  
  161. result += "array[" + i + "] = '" + cr[i] + "'/n";  
  162.  
  163. }  
  164.  
  165. }  
  166.  
  167. else  
  168.  
  169. if ( cr != null ) // 如果计算结果不为null, 则取出计算结果的值  
  170.  
  171. {  
  172.  
  173. result = cr;  
  174.  
  175. }  
  176.  
  177.  
  178.  
  179. // 获得并显示结果  
  180.  
  181. matchResult.innerText = result + ' ';  
  182.  
  183.  
  184.  
  185. // 获得并显示正则表达式的lastIndex属性  
  186.  
  187. lastIndex.innerText = re.lastIndex + ' ';  
  188.  
  189. }  
  190.  
  191. </SCRIPT>  
  192.  
  193. </HEAD>  
  194.  
  195.  
  196.  
  197. <BODY ALIGN=CENTER>  
  198.  
  199. <FORM NAME="form1" METHOD="post" ACTION="" ALIGN=CENTER>  
  200.  
  201. <TABLE BORDER="1">  
  202.  
  203. <TR>  
  204.  
  205. <TD COLSPAN="2" ALIGN="CENTER">test javascript regex</TD>  
  206.  
  207. </TR>  
  208.  
  209. <TR>  
  210.  
  211. <TD>test regex:</TD>  
  212.  
  213. <TD><INPUT NAME="regex" TYPE="text"></TD>  
  214.  
  215. </TR>  
  216.  
  217. <TR>  
  218.  
  219. <TD>test regex flags:</TD>  
  220.  
  221. <TD><INPUT NAME="flags" TYPE="text" ID="flags"></TD>  
  222.  
  223. </TR>  
  224.  
  225. <TR>  
  226.  
  227. <TD>test string:</TD>  
  228.  
  229. <TD><INPUT NAME="string" TYPE="text"></TD>  
  230.  
  231. </TR>  
  232.  
  233. <TR>  
  234.  
  235. <TD>select method:</TD>  
  236.  
  237. <TD ALIGN="CENTER">  
  238.  
  239. <SELECT NAME="select" onChange="check(this.value)">  
  240.  
  241. <OPTION VALUE="0">exec</OPTION>  
  242.  
  243. <OPTION VALUE="1">test</OPTION>  
  244.  
  245. <OPTION VALUE="2">match</OPTION>  
  246.  
  247. <OPTION VALUE="3">search</OPTION>  
  248.  
  249. <OPTION VALUE="4">replace</OPTION>  
  250.  
  251. <OPTION VALUE="5">split</OPTION>  
  252.  
  253. </SELECT>  
  254.  
  255. <INPUT VALUE='run' onclick="check(form1.select.value)" TYPE=button>  
  256.  
  257. </TD>  
  258.  
  259. </TR>  
  260.  
  261. <TR>  
  262.  
  263. <TD>dest regex:</TD>  
  264.  
  265. <TD STYLE="color:blue" ID=destRegex> </TD>  
  266.  
  267. </TR>  
  268.  
  269. <TR>  
  270.  
  271. <TD>dest expression:</TD>  
  272.  
  273. <TD STYLE="color:blue" ID=expression> </TD>  
  274.  
  275. <TR>  
  276.  
  277. <TR>  
  278.  
  279. <TD>return type:</TD>  
  280.  
  281. <TD STYLE="color:darkred" ID=returnType> </TD>  
  282.  
  283. </TR>  
  284.  
  285. <TR>  
  286.  
  287. <TD>result:</TD>  
  288.  
  289. <TD STYLE="color:red" ID=matchResult> </TD>  
  290.  
  291. </TR>  
  292.  
  293. <TR>  
  294.  
  295. <TD>regex lastIndex:</TD>  
  296.  
  297. <TD STYLE="color:red" ID=lastIndex> </TD>  
  298.  
  299. </TR>  
  300.  
  301. </TABLE>  
  302.  
  303. </FORM>  
  304.  
  305. </BODY>  
  306.  
  307. </HTML> 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表