服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS新版微信底部工具栏遮挡问题完美解决

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

2021-06-01 15:49白砂糖的白 IOS

这篇文章主要介绍了iOS新版微信底部工具栏遮挡问题完美解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、问题描述:

苹果设备(iOS)微信中打开H5页面,从首页跳转到其他页面后,页面的底部会出现一个带有前进和后退按钮工具栏,而该工具栏会遮挡住面底部的内容,影响页面的正常使用。

二、原因分析:

造成该现象的原因是,当页面跳转时,微信浏览器会通过window.history读取到浏览的历史记录,此时便会在页面底部显示出前进后退按钮的工具栏,造成页面底部内容遮挡。

三、解决方案:

了解了该问题出现的原因,我们也就有了解决办法。首先想到的方案就是控制浏览器的历史记录。由于考虑到安全性问题,浏览器的历史记录不支持删除和修改等操作,只能通过新增或替换的方式来实现对浏览历史的操作,因此可以有以下方案:

(一)方案一:将页面的路由跳转方式更换为 “replace” 方式,原生写法可以使用 window.location.replace() 替代 window.location.href ;vue中可以用this.$router.replace() 替代 this.$router.push()。

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

  • 无法使用后退功能,在其他机型(安卓机型)上后退会直接退出;
  • 跳转到某些外部页面再后退回来,底部的工具栏还会出现。

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

(二)方案二:通过history的state来监听浏览器的返回事件,通过js代码来模拟浏览器的页面后退操作,以此来解决无法后退的问题。但是该方案由于代码改动较大且页面间的跳转情况过于繁琐,暂时搁置。

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

(三)方案三:使用媒体查询,手动设置两种页面样式,通过判断机型是否为iOS来展示不同的页面样式,将iOS端的底部按钮栏位置预留出来。 但是由于首次进入页面时并无底部栏,且该方案需要判断的iOS机型和版本条件过多,样式的改动也较大,暂时搁置。

进一步分析该问题发生的原因,发现出现遮挡的主要原因是,底部的工具栏是在页面完成渲染之后才渲染的,因此才会出现覆盖原页面的问题,如果能让该工具栏优先于页面渲染,则页面的视口高度就会是浏览器去掉底部工具栏之后的高度,这样就不会出现页面内容被遮挡的问题。想到了这一层面后我有如醍醐灌顶,终于找到可以完美解决的办法了!

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

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

?
1
2
3
4
router.beforeEach((to, from, next) => {
 window.history.replaceState(null, null, window.localtion.href);
 next();
})

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

这里之所以用replaceState 而不用 pushState ,是因为后者会在浏览器中多增加一条历史数据,这会导致在浏览器后退操作时需要后退两次才可以返回到之前的页面;而使用replaceState 则是替换浏览历史中的上一条记录,用当前页面的地址替换上一条记录,本质上浏览历史是不变的,自此关于iOS端微信的底部工具栏遮挡问题就可以完美解决了。

到此这篇关于iOS新版微信底部工具栏遮挡问题完美解决的文章就介绍到这了,更多相关iOS 微信底部工具栏遮挡内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.jianshu.com/p/0a93944ed627

延伸 · 阅读

精彩推荐
  • IOSiOS中时间与时间戳的相互转化实例代码

    iOS中时间与时间戳的相互转化实例代码

    这篇文章主要介绍了iOS中时间与时间戳的相互转化实例代码,非常具有实用价值,需要的朋友可以参考下。...

    张无忌!4812021-03-09
  • IOSiOS APP实现微信H5支付示例总结

    iOS APP实现微信H5支付示例总结

    这篇文章主要介绍了iOS APP实现微信H5支付示例总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    一张小A11332021-06-01
  • IOS谈一谈iOS单例模式

    谈一谈iOS单例模式

    这篇文章主要和大家谈一谈iOS中的单例模式,单例模式是一种常用的软件设计模式,想要深入了解iOS单例模式的朋友可以参考一下...

    彭盛凇11872021-01-19
  • IOSIOS网络请求之AFNetWorking 3.x 使用详情

    IOS网络请求之AFNetWorking 3.x 使用详情

    本篇文章主要介绍了IOS网络请求之AFNetWorking 3.x 使用详情,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    总李写代码6892021-03-04
  • IOSiOS10 Xcode8适配7个常见问题汇总

    iOS10 Xcode8适配7个常见问题汇总

    这篇文章主要为大家详细汇总了iOS10 Xcode8适配7个常见问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    索马里猫10332021-02-01
  • IOSiOS常见的几个修饰词深入讲解

    iOS常见的几个修饰词深入讲解

    这篇文章主要给大家介绍了关于iOS常见的几个修饰词的相关资料,iOS修饰词包括assign、weak、strong、retain、copy、nonatomic、atomic、readonly、readwrite,文中通过示...

    郡王丶千夜7422021-05-10
  • IOSiOS逆向教程之logify跟踪方法的调用

    iOS逆向教程之logify跟踪方法的调用

    这篇文章主要给大家介绍了关于iOS逆向教程之logify跟踪方法调用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学...

    Mr.Guo11472021-04-28
  • IOSxcode8提交ipa失败无法构建版本问题的解决方案

    xcode8提交ipa失败无法构建版本问题的解决方案

    xcode升级到xcode8后发现构建不了新的版本。怎么解决呢?下面小编给大家带来了xcode8提交ipa失败无法构建版本问题的解决方案,非常不错,一起看看吧...

    Cinna丶7542021-02-03