IOS下iframe页面宽度变大的Bug

最近项目中有涉及到富文本的功能,既然有了富文本,那就不可避免的涉及到添加超链接,所以就要对超链接进行校验,如果不是正确的绝对路径的超链接,我们前端就不能让用户保存,因为项目是单页面应用,如果超链接使用的是相对路径,也就是不加超文本协议,这样在app访问超链接就会跳转到项目中一个不存在的页面,那这样的体验肯定是不行的。
所以就需要在pc端保存富文本内容前就对超链接进行校验,刚开始的思路是这样的:

1、获取富文本所生成的字符串this.content
2、使用获取字符串中<a></a>标签的正则进行匹配。

const reg = /<a\s(\s*\w*?=".+?")*(\s*href=".+?")(\s*\w*?=".+?")*\s*>[\s\S]*?<\/a>/g;
let num = this.content.match(reg); //返回的是匹配成功的数组,如果为空,则返回null

3、使用匹配获取超链接的正则进行匹配。

const http  = new RegExp("(http[s]{0,1})://[a-zA-Z0-9\\.\\-]+\\.([a-zA-Z]{2,4})(:\\d+)?(/[a-zA-Z0-9\\.\\-~!@#$%^&amp;*+?:_/=<>]*)?", "gi");  //第二种创建正则的写法
let httpNum = this.content.match(http);

4、然后对比numhttpNum数组的长度,如果相同就意味着每个超链接都是正确的。

这样写完代码后觉得很完美,但是逃不过测试的检验,果不其然提了一个bug,那就是如果<a></a>标签的内容中也存在超链接,那么这样判断就彻底不管用了。那好吧,只能接着改正则了。

经过前端的讨论我们决定在匹配超链接的正则前面加上匹配href="的正则,但还是有一个bug,就是内容里的超链接前面也有href=",Em....,不管了,先上一版再说。等以后有更好的方案了再来更新。

现在超链接的问题是“完美”解决了,而且app跳转超链接的做法是前端再写一个页面,页面上就是iframe,里面的src属性就是跳转的超链接,在展示富文本的页面加上click事件阻止默认的跳转事件。

openImageProxy: function (event) {
// 判断点击的是否是A标签(nodeName属性都是大写)
if (event.target.nodeName === 'A') {
    //阻止默认的事件
    event.preventDefault();
    let fullPath = this.$route.fullPath;
    //获取超链接地址
    let param = event.target.href;
    //获取A标签的内容,方便在新页面设置title
    let desc = event.target.innerText;
    //跳转到新页面
    this.$router.push({path:'linkTo',query:{param,desc,fullPath}});
    }
}

正当我以为这个功能改好的时候,测试又来一个bug,说这个iframe页面在ios系统中变得很大,我一看还真是,特别的丑,这就不能忍了赶紧改。

经过我的调试,发现只有ios有这个问题,Android的表现很完美。于是我就上网搜到了一个解决方案:

产生原因:iOS下的safari是按照iframe里面页面元素的全尺寸来调整iframe的大小的。

在iframe上设置以下样式:

iframe {
  width: 1px;
  min-width: 100%;
  *width: 100%;
}

同时设置scrolling属性为’no’。

<iframe :src="temp" class="iframe-temp" scrolling="no"></iframe>

然后拿起苹果手机打开一看,很完美。拿起安卓手机打开一看,无法滚动了,Em....
既然scrolling属性为’no’是特意针对ios设置的,那干脆就判断一下客户端类型来分别展示吧!如果是ios,那就设置scrolling属性,如果是Android,那就不需要。

window.navigator.userAgent.toLowerCase().indexOf('iphone');
//通过检测客户端类型中是否有'iphone'来判断操作系统。
//然后再通过Vue的v-if指令来渲染不同的iframe

以上就是关于遇到的iframe的bug并解决它的方案。里面用到了match()匹配正则的方法,那么下次就来记录一下所有的涉及到正则的方法。

参考资料:iOS的iframe宽度bug

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 上一章 目录 平日只道安国冬日霜冷雪寒,到了沙场,方觉得这沙场的风雪才是真的凛冽,算上我昏睡的两日,这大雪已是纷纷...
    末晓阅读 612评论 6 10
  • 三月是离职高发期,特别是在软件、互联网公司。那些程序猿们拿完上年度的年终奖后,安心或郁闷的过完一个春节蛰伏期后,...
    双鱼座的猫阅读 677评论 3 48