iOS新版微信底部工具栏遮挡问题完美解决.pdfVIP

iOS新版微信底部工具栏遮挡问题完美解决.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

iOS新新版版微微信信底底部部工工具具栏栏遮遮挡挡问问题题完完美美解解决决

主要介绍了iOS新版微信底部工具栏遮挡问题完美解决,文中通过示例代码介绍的常详细,对大家的学习或者

工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一一、、问问题题描描述述::

苹果设备(iOS)微信中打开H5页面,从首页跳转到其他页面后,页面的底部会出现一个带有前进和后退按钮工具栏,而该工

具栏会遮挡住面底部的内容,影响页面的正常使用。

二二、、原原因因分分析析::

造成该现象的原因是,当页面跳转时,微信浏览器会通过window.history读取到浏览的历史记录,此时便会在页面底部显示出

前进后退按钮的工具栏,造成页面底部内容遮挡。

三三、、解解决决方方案案::

了解了该问题出现的原因,我们也就有了解决办法。首先想到的方案就是控制浏览器的历史记录。由于考虑到安全性问题,浏

览器的历史记录不支持删除和修改等操作,只能通过新增或替换的方式来实现对浏览历史的操作,因此可以有以下方案:

(一)方案一:将页面的路由跳转方式更换为“replace”方式,原生写法可以使用window.location.replace()替代

window.location.href;vue中可以用this.$router.replace()替代this.$router.push()。

本以为这样就可以解决该问题,但是经过测试发现该方案也会出现一些弊端:

无法使用后退功能,在其他机型(安卓机型)上后退会直接退出;

跳转到某些外部页面再后退回来,底部的工具栏还会出现。

为了解决第一个问题,想到了第二个方案——监听浏览器返回功能:

(二)方案二:通过history的state来监听浏览器的返回事件,通过s代码来模拟浏览器的页面后退操作,以此来解决无法后退

的问题。但是该方案由于代码改动较大且页面间的跳转情况过于繁琐,暂时搁置。

考虑到操作history比较繁琐,转而考虑是否可以通过修改样式来实现兼容:

(三)方案三:使用媒体查询,手动设置两种页面样式,通过判断机型是否为iOS来展示不同的页面样式,将iOS端的底部按

钮栏位置预留出来。但是由于首次进入页面时并无底部栏,且该方案需要判断的iOS机型和版本条件过多,样式的改动也较

大,暂时搁置。

进一步分析该问题发生的原因,发现出现遮挡的主要原因是,底部的工具栏是在页面完成渲染之后才渲染的,因此才会出现覆

盖原页面的问题,如果能让该工具栏优先于页面渲染,则页面的视口高度就会是浏览器去掉底部工具栏之后的高度,这样就不

会出现页面内容被遮挡的问题。想到了这一层面后我有如醍醐灌顶,终于找到可以完美解决的办法了!

(四)最终方案:在页面加载之前通过主动添加空的历史记录,触发浏览器的history监听机制,让浏览器先于页面调出底部工

具栏,从而解决遮挡问题。

所以我们需要在路由守卫中增加对window.history的处理,代码如下:

router.beforeEach((to,from,next)={

window.history.replaceState(null,null,window.localtion.href);

next();

})

由于项目使用的是vue,这里只展示vue中的写法,使用其他写法的同学可以类比一下。

这里之所以用replaceState而不用pushState,是因为后者会在浏览器中多增加一条历史数据,这会导致在浏览器后退操作时

需要后退两次才可以返回到之前的页面;而使用replaceState则是替换浏览历史中的上一条记录,用当前页面的地址替换上一

条记录,本质上浏览历史是不变的,自此关于iOS端微信的底部工具栏遮挡问题就可以完美解决了。

到此这篇关于iOS新版微信底部工具栏遮挡问题完美解决的文章就介绍到这了,更多相关iOS微信底部工具栏遮挡内容请搜索我

们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

文档评论(0)

wszwtlg202 + 关注
实名认证
文档贡献者

一页纸且

1亿VIP精品文档

相关文档