• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >正则表达式 > 浏览器中的正则表达式陷阱说明

浏览器中的正则表达式陷阱说明

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了正则表达式,手机号正则表达式,正则表达式测试工具,python 正则表达式,java正则表达式教程等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

在本章开始前 我要引入一个例子 来说明这种不彻底的 变态的优化 到底合理还是不合理...

c# 中的 字符串直接量 做的优化 就非常彻底...这种优化我们应该是欢迎的...

 string str="franky";

string str2="franky";

在内存中 只有一份 字符串对象 而str和str2 具备相同的一份引用. 很明显 这非常合理.

string n = "franky",  n2 = "franky";
Response.Write((Object.ReferenceEquals(n,n2)).ToString());//True.

那么 一些特殊情况下  有些浏览器 为正则表达式直接量也做了类似的优化.

alert(/\d/==/\d/);//所有浏览器都是false 这很合理 因为正则表达式直接量 同 [] 数组直接量 {}对象直接量一样 都是引用类型 

我们再看看哪些情况下哪些浏览器做了优化

    function f2() {
        return /\d/;
    }

       alert(f2() == f2());

//这里的结果就有不同了

ie6 7 8  opear10 safari4 都返回false  (我虚拟机里safari3坏了没做测试.如果谁有 帮忙测下告诉我结果.谢谢 我估计safari3 会返回true.原因是 maxthon3用的引擎貌似就是safari3 的) 

但是

firefox 2.0 3.0+ 3.5 3.6  chrome 4 5 opear9  maxthon3 demo版  使用webkit引擎下 都返回true

有趣的地方在于 opera9 做了优化 而opera10 取消了这种优化. 看来至少opera团队认为这种优化时不恰当的...(变相支持了我的观点.)

 

看到这里 你也许会奇怪 是不是 bug而不是所谓优化啊? 也许是闭包对象 出了什么问题或者 是 函数对象上的某些bug引起的?

那么我们看看下面的例子:

for (var i = 0; i < 10; i++) document.writeln(/\d/g.test('' + i));

不同浏览器 输出结果的 差异 完全符合上面 是否做优化的分类.

即没有 做优化的浏览器 一律返回true 而作了优化的浏览器 则是 true false true false 交替的结果.

我们这里只是一个 循环 ..js中的循环没有独立的作用域 更不会产生闭包对象 那么可以肯定 引起这个怪异问题的 根本原因就是某些浏览器自作聪明的优化.

可能大家不太理解 test的结果 差异来自哪里...  答案是 test 同 exec 一样 如果 直接量后面有/g  .设置了 global全局查找参数 的话 那么 同一个test对象 会记录上次 匹配字符的索引位置.下次再 匹配时 会从这个位置开始..如果没有 则 匹配索引<0 下次在此匹配时 就仍然从0位置字符开始.

所以上面这个测试 使用 exec 也是可以的.

那么 这里 如何避免浏览器差异呢? 简单的办法 去掉/g即可

这里我们为了躲避陷阱 就要 记得一个约定.  请尽量不要使用 一个正则直接量 在函数体内 或 循环内. 如果一定要如此 请使用new RegExp('\d',g);这种.

对于exec 尽量用 string.match代替. 因为match 强制你依靠是否有 /g 来全局查找..不会产生歧义.

对于test 如果是循环内 也可以考虑  var reg=/\d/; //这里要吧/g去掉..请不要忘记哦

for (var i = 0; i < 10; i++) document.writeln(reg.test('' + i));

事实上这样用是最合理的办法 .原因是 这里我们只产生一个正则对象 并反复使用他.. 本质上也是为了优化。但是我们避开了 浏览器自己的优化差异 导致的不同结果.

最后我们发现 所谓陷阱 发生主要是 /g使用不当.无论是 exec 还是test都是如此  如果合理使用/g 无论浏览器是否存在变态的优化. 执行结果都将是正确的...唯一的区别 只在于 做了优化的浏览器 不需要反复产生一个 正则对象然后再垃圾回收 再产生一个正则对象....如此反复而已...

那么我们发现 遵守上面几个原则的话 这种问题 也都避免了...

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 最全正则表达式总结:验证QQ号、手机号、Email、中文、邮编、身份证、IP地址等
  • 正则表达式技术详解 Regular Expression
  • 最全的常用正则表达式大全——包括校验数字、字符、一些特殊的需求等等
  • 正则表达式之零宽断言实例详解【基于PHP】
  • 正则表达式中环视的简单应用示例【基于java】
  • 除捕获组的语法外,其它的(?...)语法都不是捕获组的验证
  • 正则表达式——详细讲解平衡组
  • 正则表达式的多行模式与单行模式图文分析
  • JavaScript的正则也有单行模式了
  • JS正则表达式一条龙讲解(从原理和语法到JS正则)

相关文章

  • 2017-05-11JAVA中正则表达式小总结(整理)
  • 2017-05-11代替正则——HyperScriptExpression联合开发倡议公告
  • 2017-05-11比较实用的正则表达式学习笔记
  • 2017-05-11正则表达式m修饰符(多行匹配)
  • 2017-05-11使用正则表达式替换报表名称中的特殊字符(推荐)
  • 2017-05-11利用正则表达式抓取博客园列表数据
  • 2017-05-11读懂正则表达式就这么简单
  • 2017-05-11使用正则表达式替换表情符号核心代码
  • 2017-05-11ubb代码转换为html
  • 2017-05-11javascript中使用正则表达式删除前后空格的方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 经典JavaScript正则表达式实战(附pdf)
    • 正则表达式\d元字符(相对于数字0-9)
    • 正则表达式(regex)或操作符”|“使用易出现功能Bug
    • PHP中正则表达式对UNICODE字符码的匹配方法
    • 限制文本框中只能输入实数或整数,其它字符无效,有劳大家了!
    • php中正则表达式中的特殊符号
    • 在Asp中用“正则表达式对象”来校验数据的合法性
    • js:校验IPv6地址的正则表达式
    • 正则表达式 匹配至少有一个非空白字符并且不超过指定长度
    • PHP preg match正则表达式函数的操作实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有