js正则表达式之RegExp对象之compile方法 编译正则表达式
功能说明:该方法可以编译指定的正则表达式,编译之后的正则表达式执行速度将会提高,如果正则表达式多次被调用,那么调用compile方法可以有效的提高代码的执行速度,如果该正则表达式只能被使用一次,则不会有明显的效果。
基本语法:objReg.compile(pattern[,flag])
objReg必选项,RegExp对象变量的名称
pattern 必选项 正则表达式
flag 可选项 匹配选项
<html>
<script language="javascript" type="text/javascript">
//要匹配的字符串
var objStr="我的手机号13522222222,他的手机号码13233333333她的手机号码13988888888";
//设置正则表达式匹配以13开头的11为手机号码,全局匹配(这里是匹配移动手机号)
var reg=new RegExp("13[4-9](//d){8}","g");
//提示用户发现移动号码,然后打印出结果
document.write("发现移动手机号码");
//调用函数打印匹配的结果
findPhoneNumbers(objStr.match(reg));
//重新编译正则表达式
reg.compile("13[0-3](//d){8}","g");
document.write("发现联通手机号码");
findPhoneNumbers(objStr.match(reg));
//定义输出返回结果函数
function findPhoneNumbers(arr){
//使用循环输出数据
for(var i=0;i<arr.length;i++){
document.write("<li>"+arr[i]+"<br>");
}
}
</script>
</html>
使用compile方法还可以对指定的正则表达式进行修改并且重新编译,提高了正则表达式的适应性!
相关推荐
-
js正则表达式test()和exec()用法实例
本文实例讲述了js正则表达式test()和exec()用法.分享给大家供大家参考.具体如下: 复制代码 代码如下: <html> <head> <script type="text/javascript"> //正则.test(内容),返回true或false function t1(){ var con = document.getElementsByName('content')[0].value;//需要查找的内容 var reg = /h
-
JavaScript RegExp 正则表达式对象详细说明
直接量语法 /pattern/attributes 创建 RegExp 对象的语法: 复制代码 代码如下: var obj=new RegExp(pattern,attributes); 事例1: 复制代码 代码如下: var pattern=/a/; document.write(pattern.exec("asdas")); 事例2: 复制代码 代码如下: var obj=new RegExp("a"); document.write(obj.exec(&quo
-
JS正则RegExp.test()使用注意事项(不具有重复性)
本文实例分析了JS正则RegExp.test()使用注意事项.分享给大家供大家参考,具体如下: 先看下面这段代码: // 2012-12-12 12:12:12 var regex = /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}/g; // true alert(regex.test("2012-12-12 12:12:12")); // false alert(regex.test("2012-12-12 12:12:12")); 执
-
详解JavaScript正则表达式之RegExp对象
一.RegExp对象概述 RegExp对象表示正则表达式,RegExp是正则表达式的缩写,它是对字符串执行模式匹配的强大工具.RegExp对象用于规定在文本中检索的内容.当您检索某个文本时,可以使用一种模式来描述要检索的内容.RegExp就是这种模式.简单的模式可以是一个单独的字符:更复杂的模式包括了更多的字符,并可用于解析.格式检查.替换等. 正则表达式可以规定字符串中的检索位置,以及要检索的字符类型等. 二.创建RexExp对象 创建正则表达式和创建字符串类似,创建正则表达式有
-
浅谈JS正则表达式的RegExp对象和括号的使用
RegExp对象的创建: 常规的正则表达式的创建可用直接量,即斜杠 "/" 括起来的字符.但在要求参数变化的环境下,RegExp()构造函数是更好的选择: var reg1 = /'\w+'/g; var reg2 = new RegExp('\'\\w+\'','g'); 对比两种创建方式,RegExp中的第一个参数为要创建的正则字符串,一方面注意,因为不是直接量的表示形式,因此不用斜杠" / "括起来了:而是字符串中必须要对引号" ' "和转
-
JavaScript 正则表达式之RegExp属性、方法及应用分析
使用RegExp的显式构造函数,语法为:new RegExp("pattern"[,"flags"]). 使用RegExp的隐式构造函数,采用纯文本格式:/pattern/[flags]. pattern部分为要使用的正则表达式模式文本,是必须的.在第一种方式中,pattern部分以JavaScript字符串的形式存在,需要使用双引号或单引号括起来:在第二种方式中,pattern部分嵌套在两个"/"之间,不能使用引号. flags部分设置正则表达
-
js正则表达式之input属性($_)RegExp对象属性介绍
功能说明:该属性为RegExp的静态只读属性,该属性的值为与RegExp对象所描述的正则表达式进行匹配检测的字符串,该属性也可以表示成$_ 复制代码 代码如下: <html> <script language="javascript" type="text/javascript"> //objStr 为待匹配的内容 var objStr='abcDdefCDDE'; //创建正则表达式,i表示匹配忽略大小写 var re=/cd+e/i;//
-
javascript RegExp对象(正则表达式)
使用RegExp的显式构造函数,语法为:new RegExp("pattern"[,"flags"]). 使用RegExp的隐式构造函数,采用纯文本格式:/pattern/[flags]. pattern部分为要使用的正则表达式模式文本,是必须的.在第一种方式中,pattern部分以JavaScript字符串的形式存在,需要使用双引号或单引号括起来:在第二种方式中,pattern部分嵌套在两个"/"之间,不能使用引号. flags部分设置正则表达
-
浅谈js中test()函数在正则中的使用
test() 方法用于检测一个字符串是否匹配某个模式. 返回一个 Boolean 值,它指出在被查找的字符串中是否匹配给出的正则表达式. regexp.test(str) 参数 regexp 必选项.包含正则表达式模式或可用标志的正则表达式对象. str 必选项.要在其上测试查找的字符串. 说明 test 方法检查字符串是否与给出的正则表达式模式相匹配,如果是则返回 true,否则就返回 false. 每个正则表达式都有一个 lastIndex 属性,用于记录上一次匹配结束的位置. var
-
JavaScript正则表达式小结(test|match|search|replace|split|exec)
学JavaScript正则的好文一篇:http://www.cainiao8.com/web/js_note/js_regular_expression.html test:测试string是否包含有匹配结果,包含返回true,不包含返回false. <script type="text/javascript"> var str = "bbs.byr.cn"; var reg = /b/; var ret = reg.test(str); alert(r
-
JS正则中的RegExp对象对象
有两种方式可以创建RegExp对象的实例. 使用RegExp的显式构造函数,语法为:new RegExp("pattern"[,"flags"]). 使用RegExp的隐式构造函数,采用纯文本格式:/pattern/[flags]. pattern部分为要使用的正则表达式模式文本,是必须的.在第一种方式中,pattern部分以JavaScript字符串的形式存在,需要使用双引号或单引号括起来:在第二种方式中,pattern部分嵌套在两个"/"之间
-
javascript 正则替换 replace(regExp, function)用法
复制代码 代码如下: function fn() { for(var i = 0;i < arguments.length;i++){ alert("第"+(i+1)+"个参数的值:"+arguments[i]); } } var str = '<div id="{wo}" >{ni}</div>'; str.replace(/\{([a-z]+)\}/ig, fn); 根据多次测试由输出结果可以得出fn中: 第一个
随机推荐
- 用prototype实现的简单小巧的多级联动菜单
- 编写你的shell其实很简单
- MYSQL更新优化实录
- 浅谈springmvc的DispatcherServlet分析
- 来自国外的页面JavaScript文件优化
- js实现动态加载脚本的方法实例汇总
- javascript实现动态标签云
- MySQL定义异常和异常处理详解
- Java中的静态绑定和动态绑定详细介绍
- C#中Array与ArrayList用法及转换的方法
- Win2003 IIS浏览ASP提示无法找到该页的解决办法
- jquery结婚电子请柬特效源码分享
- Android利用CountDownTimer实现倒计时功能 Android实现停留5s跳转到登录页面
- Hibernate中的多表查询及抓取策略
- Android自定义封装banner组件
- 非常漂亮的让背景如此暗淡(一种弹出提示信息时页面背景色调改变的方法)
- Span元素的width属性无效果原因及解决方案
- Win7环境下Apache连接MySQL提示连接已重置的解决办法
- 改进的IP计数器
- 详解用webpack的CommonsChunkPlugin提取公共代码的3种方式