关于APP内嵌H5页返回按钮的问题

用h5做了一个简单的攻略页,浏览页面20s后会调接口自动发放一个攻略红包,
当浏览页面不到20s 点击页面顶部的返回按钮要先清定时器,然后再返回上一页,
h5页面是react单页面
在这里插入图片描述

这个h5页是被内嵌在微信小程序和ios、安卓的app里
首先在小程序里用web-view把h5页引进来,顶部的返回是小程序原生的就可以完成这个功能,
点击返回的时候,页面就会销毁, react页面销毁会执行componentWillUnmount,所以在这个生命周期里清定时器就好了

但是ios 安卓里用这种方法却没办法清除定时器,简单做了个实验
安卓app里,点击手机上自带的物理返回键是可以清除定时器的,说明componentWillUnmount执行了,页面是真正的销毁,
但是点击页面上的返回按钮是清除不了定时器的
所以初步断定安卓页面上原生的返回按钮有可能不是销毁页面,有可能只是把页面隐藏了。

所以要想在app里点返回按钮,返回上一页之前去清除定时器,只能让app把原生的返回功能隐藏掉,
h5自已写一个返回栏,在点击返回按钮的时候,先清定时器,然后再调ios 安卓提供的方法返回上一页。

此文章特此记录下项目中遇到的问题,希望可以帮到有类似需求的小伙伴,有更好的方法的大神也来指导下~

随着互联网的发展,移动互联网的普及,手机APP已成为人们使用最多的移动终端产品之一。随着越来越多的APP应用的涌现,越来越多的APP需要内嵌H5面WebView进行网的展示和交互。WebView是一种可在应用程序中嵌入Web面的控件,可以用来显示来自互联网上的Web面。它可以实现在应用中展示网或在线功能,解决一些本地应用无法实现的功能。下面,我们分别从用户、开发者两个方面来探讨APP内嵌H5面WebView的优缺点。 一、用户方面: 优点: 1.节省时间:在APP中直接查看嵌入的网,省去了用户手动打开浏览器输入网址的步骤; 2.良好的用户体验:面加载速度相对较快,而且对主应用对内存占用少,不影响其他应用的使用; 3.方便分享:在WebView中打开的网可以长按复制网址链接,方便分享给其它用户; 4.强大的交互能力:在APP中嵌入H5面,拓展了应用的交互能力。 缺点: 1.便捷性带来的安全隐患:一些App会在内嵌H5面中嵌入第三方广告,导致用户隐私泄露; 2.缺乏统一标准:因为浏览器的内核和引擎都是不同的,所以在不同的WebView中,同一网的显示效果和交互体验可能会有差异。 二、开发者方面: 优点: 1.拓展应用功能:借助WebView内嵌H5面,应用的功能可以得到极大的拓展; 2.代码复用:WebView可以实现HTML、CSS等内容的兼容,减轻了移动开发者负担; 3.节省开发成本:相对于开发单独的H5 APP内嵌方式更为灵活,可以适用于不同场景和需求。 缺点: 1.不支持多线程:WebView在JS调用本地方法的时候是在同一线程下执行的,如果WebView的内容较为复杂,可能会导致主线程卡顿; 2.性能问题:在内存管理、布局排版等方面还不如原生应用; 3.浏览器兼容性:WebView的内核并没有得到很好的统一,不同的WebView之间有兼容性问题,会导致面显示和交互问题; 4.安全问题:WebView加载HTML面时容易受到跨站脚本(XSS)和恶意代码注入等安全漏洞的攻击。为此,开发者应该加强前端面安全防范,对浏览器缓存和Cookie进行管理并开启CSP(内容安全策略)。 综合来看,在APP内嵌H5面WebView上,开发者需要在开发时注意安全方面的问题,同时还需要加强对WebView性能和兼容性的了解和优化。用户便捷性和良好的用户体验,也需要开发者在开发时重视。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值