排坑·IPhone&IOS中不兼容正则中的断言匹配
| 阅文时长 | | 1.14分钟 | 字数统计 | | 1834.4字符 |
| 主要内容 | | 1、问题切入 2、什么是断言匹配 3、断言匹配的替换方案 4、声明与参考资料 |
||
| 『排坑·IPhone&IOS中不兼容正则中的断言匹配』 | |||
| 编写人 | | SCscHero | 编写时间 | | 2020/12/7 AM12:14 |
| 文章类型 | | 单篇 | 完成度 | | 已完成 |
| 座右铭 | 每一个伟大的事业,都有一个微不足道的开始。 | ||
一、问题切入 完成度:100%
a) 问题发现
PC端谷歌、QQ、Edge浏览器正常运行,移动端安卓设备可以正常运行的正则。 Macbook没有测试 (没有Mac电脑) 。 在IPhone系设备,IOS系统中的Safari浏览器、QQ浏览器都出现报错。报错信息在JS中使用try..catch语句获取到:SyntaxError:Invalid regular expression:invalid group specifier name。
b) 问题分析&排查方向
报错分析:
报错翻译过来是"正则表达式无效:组说明符名称无效。",推测是正则中的分组问题,然后经查其他使用正则的接口都是正常的,但出错接口是因为含有断言匹配。于是乎方向似乎明确了,IPhone设备可能将断言匹配当做了普通分组,于是为了兼容IPhone设备,改用分组写法匹配数据,详见例子。
解决过程/排查方向/摸索过程(可跳过看下面解决方案):
【错误方向1】首先,由于在其他设备、系统中都可以正常运行。于是以为是CSS前缀问题,于是检查了postcss-loader、autoprefixer插件。正常无问题。
【错误方向2】然后,检查了下ES6语法是否转换了ES5,检查了babel配置,仍然没问题。
【错误方向3】接着,想直接在IPhone机调试,发现无法调试。于是寻找可调试方案。
- 需要使用Macbook电脑,由于没有硬件设备,于是寻找可替代方案。
- 使用windows系统模拟Safari网页。此种方法需要安装一大堆环境,由于担心安装过程中又出现一大堆坑,于是继续寻找可替代方案。
- 于是使用异常捕获,在出错接口中弹出。捕获了异常。
c) 解决方案
改写断言匹配的正则表达式内容,以其他正则表达式内容替代。详见例子。
二、什么是断言匹配 完成度:100%
a) 个人理解
断言匹配是什么?断言匹配是正则表达式中的一个概念。博主在Google了一下,没有官方的定义,但在中文中基本叫断言匹配。断言匹配大致分为四种。详见下文。
断言匹配作用/用途?是正则表达式的条件语句。断言匹配的原子组,不会被正常的分组。所以在匹配的时候,可以只匹配需要的部分。
b) 名词普及
- (?!)零宽负向先行断言
- (?=)零宽先行断言
- (?<=)零宽后行断言
- (?<!)零宽负向后行断言。
c) 通俗解释
- ?!后面不是什么
- ?=后面是什么
- ?<=前面是什么。
- ?<!前面不是什么
d) 详细示例
下面本人使用JS的正则表达式的三个小例子来做示例。
{
//案例:替换除了pre标签的其他标签为p标签。
let str = `
<h1>h1 label content</h1>
<pre>pre label content</pre>
<span>span label content</span>
`;
let reg = /<(?!pre)(.*?)>(?<content>[\s\S]+?)<\/\1>/g;
let repReg = str.replace(reg, "$<content>");
console.log(repReg);
}
{
//案例:将所有元前面数字统一加上.00;
let str = `
500,1000.00,1500
`;
let reg = /(\d+)(.00)?/g;
console.log(reg.exec(str));
//v,匹配值。args,详细数组。
let res = str.replace(reg, (v, ...args) => {
console.log(args);
args[1] = args[1] || ".00";
return args.splice(0, 2).join("");
});
console.log(res);
}
{
//案例:匹配字母后面的数据
let str = "SCscHero123";
let reg = /(?<=SCscHero)\d+/i;
console.log(str.match(reg));
}
{//案例:匹配字符串中不能出现SC字母
let str = "SSSCscHero";
//即起始的后面,不能出现SC
console.log(str.match(/^(?!.*SC.*).*$/));
}
三、断言匹配的替换方案 完成度:100%
断言匹配的替换方案还是挺多的,主要目的就是分析字符串,达到你的目的即可(基本是废话,手动滑稽)。下面用本人的一个例子讲一下怎么处理。
【要求】从下面的字符串中提取需要的数字。
【分析】只需要提取数字,前后有固定的规律,因此符合使用断言匹配的条件。同样,也可以使用分组匹配提取其中的内容。
{//使用断言匹配写法
let str = "SCscHero123SCscHero";
let reg = /(?<=SCscHero)\d+(?=SCscHero)/g;
console.log(str.match(reg)[0]);
{//使用分组替换写法
let str = "SCscHero123SCscHero";
let reg = /SCscHero(\d+)SCscHero/;
console.log(str.match(reg)[1]);
}
这只是个小例子哈,如果有其他问题解决不了的,请留言博客。让博主也想想办法,目前只能想到这个应用。
四、声明与参考资料 完成度:100%
原创博文,未经许可请勿转载。
如有帮助,欢迎点赞、收藏、关注。如有问题,请评论留言!如需与博主联系的,直接博客私信SCscHero即可。
排坑·IPhone&IOS中不兼容正则中的断言匹配的更多相关文章
- 排坑·ASCII码为160的空格(nbsp)
阅文时长 | 2.83分钟 字数统计 | 1345.2字符 『排坑·ASCII码为160的空格(nbsp)』 编写人 | SCscHero 编写时间 | Wednesday, September 9, ...
- JS IOS/iPhone的Safari不兼容Javascript中的Date()问题
var date = new Date('2016-11-11 11:11:11'); document.write(date); 最近在写一个时间判断脚本,需要将固定好的字符串时间转换为时间戳进行比 ...
- 【js】【ios】【safari】【兼容问题】【转发】JS IOS/iPhone的Safari不兼容Javascript中的Date()问题
引用地址:http://www.cnblogs.com/yiven/p/6053872.html 1 var date = new Date('2016-11-11 11:11:11'); 2 d ...
- 记一次事件委托在 ios 下的兼容 bug
项目中碰到的兼容类 bug,记录一二. 页面上有几个同类型的控件,点击它们会触发一些事件,很显然,事件委托优于批量绑定.为了图方便,我将 click 事件绑定到了 document.body 上(绑定 ...
- iOS 的 APP 在系统中如何适配不同的屏幕的尺寸
iOS 的 APP 在系统中如何适配不同的屏幕的尺寸 标签: 2007年,初代iPhone发布,屏幕的宽高是 320 x 480 像素.下文也是按照宽度,高度的顺序排列.这个分辨率一直到iPhone ...
- iOS逆向工程之Hopper中的ARM指令
虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学.现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少的实验,当时自我感觉ARM这门课学的还是 ...
- Spring-Cloud之Eureka排坑之旅
1 快速demo 1.0 环境说明 Intelli IDEA+Spring Boot 1.1 新建工程chap52(通过New Project->Spring Initializer-> ...
- 移动端开发ios和安卓兼容问题
移动端开发ios和安卓兼容问题 最近做移动端混合开的时候遇到一些安卓和iOS的兼容性问题,兼容想问题不仅在浏览器存在也在APP开发当中也会经常遇到这样的情况. 最近看了一下内容很不错的移动端开发相关的 ...
- 初次见面C#排坑记录
排一次开发C#遇到的坑,同时说一下自己对C#中文件夹构建方式的体会. 一个开发Java的人留下了痛苦的泪水,变量命名规则不一样,连括号打的都不一样,
随机推荐
- Android 之 TableLayout 布局详解
TableLayout简介 •简介 Tablelayout 类以行和列的形式对控件进行管理,每一行为一个 TableRow 对象,或一个 View 控件. 当为 TableRow 对象时,可在 Tab ...
- C/C++ 中的算术及其陷阱
目录 概述 C/C++ 整数的阴暗角落 整型字面量 整型提升与寻常算术转换 算术溢出检测 位运算技巧 总结 参考 概述 无符号数和有符号数是通用的计算机概念,具体到编程语言上则各有各的不同,程序员是解 ...
- OOP第一次博客作业
一.关于Java&&面向对象 本学期刚开始进行Java的学习,也是刚开始了解面向对象,目前也就学习了三四周的样子,期间进行了三次作业,我感觉到Java的语法和c语言中的有许多相似之处, ...
- 复制文件--cp
cp file1 file2 将文件拷贝到指定路径下 cp -r dir1 dir2 将文件夹拷贝到指定路径下
- java面试-内存分配与回收策略
1.对象优先在Eden分配 -Xms20M -Xmx20M java堆的大小20M -Xmn10M 新生代10M 老年代10M -XX:SurvivorRatio=8 新生代Eden与一个Surviv ...
- docker命令快速入门
docker快速入门系列 Docker hello world hello world $ docker run ubuntu:15.10 /bin/echo "Hello world&qu ...
- Android-SQLite的介绍 以及四个基本操作~
在Android 开发中SQLite起着很重要的作用,网上SQLite的教程有很多很多,不过那些教程大多数都讲得不是很全面.本人总结了一些SQLite的常用的方法,借着论坛的大赛,跟大家分享分享的.一 ...
- Spring Security OAuth 格式化 token 输出
个性化token 背景 上一篇文章<Spring Security OAuth 个性化token(一)>有提到,oauth2.0 接口默认返回的报文格式如下: { "ac ...
- forEach和map的用法和区别
forEach()和map()都是处理数组的高阶函数有相同的三个值:(currentValue,index,arr): currentValue:必选,当前元素的值,index:可选,当前元素的下标, ...
- Linux 基本防火墙设置和开放端口命令
关闭防火墙 CentOS 7.RedHat 7 之前的 Linux 发行版防火墙开启和关闭( iptables ): 即时生效,重启失效 #开启 service iptables start #关闭 ...