国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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> 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 博客| 大洼县| 湖口县| 秭归县| 虞城县| 镇宁| 鄂托克前旗| 张家港市| 兴国县| 荥阳市| 时尚| 琼结县| 阿坝县| 东阿县| 广丰县| 宁蒗| 吴桥县| 汉中市| 阳高县| 常德市| 图木舒克市| 寿光市| 巴青县| 苗栗市| 宝坻区| 黎城县| 南皮县| 苍溪县| 慈溪市| 伊宁市| 永济市| 师宗县| 白城市| 汕头市| 平陆县| 绥化市| 唐山市| 柯坪县| 巫山县| 微山县| 清河县|