记一次safari浏览器正则表达式兼容问题

4 篇文章 0 订阅

在这里插入图片描述





发现问题

在开发过程中难免会使用正则表达式来匹配或替换一些文本(字符串),原本以为在不同的浏览器,正则表达式是一样的。然而在实际开发测试中却遇到了问题。

一般正则表达式使用的谷歌浏览器,火狐浏览器都正常,而在safari浏览器会莫名的报错:
在这里插入图片描述

SyntaxError: Invalid regular expression: invalid group specifier name

意思就是,正则表达式无效:组说明符名称无效。

当初所用表达式如下:

 let preg = /(?<=>)(.|\s)*?(?=<\/?\w+[^<]*>)/g;

这也是一般的写法。



解决问题

报出这个错误的原因有两点:


1、正则格式不对

尝试修改,首先改变正则的写法,如下:

 let preg = new RegExp("(?<=>)(.|\\s)*?(?=<\\/?\\w+[^<]*>)", 'g');

执行后还是会报相同的错误:
在这里插入图片描述

2、IOS,MAC不支持零宽断言

那什么是零宽断言?

用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言),因此它们也被称为零宽断言。最好还是拿例子来说明吧: 断言用来声明一个应该为真的事实。正则表达式中只有当断言为真时才会继续进行匹配。

正则零宽断言,一共4种
1、(?=xxx) 例:\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分
2、(?<=xxx) 例:(?<=\bre)\w+\b会匹配以re开头的单词的后半部分
3、(?!xxx) 例:\d{3}(?!\d)匹配三位数字,而且这三位数字的后面不能是数字
4、(?<!xxx) 例:(?<![a-z])\d{7}匹配前面不是小写字母的七位数字

在我上面所书写的正则表达式中,就用到了零宽断言?<=>?=<
尝试再次修改,如下:

 let preg = new RegExp("(<\/?[\\w]+[^>]*>)(.[^<]*)?", 'g');

然后再在业务逻辑中处理即可。

改完后再次运行程序,就正常了。



END


如有问题请在下方留言。

或关注我的公众号“孙三苗”,输入“联系方式”。获得进一步帮助。

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值