问题
用react开发的H5项目在移动端中遇到了兼容性的问题:
在页面a,点击提交按钮后,按钮状态置灰,并跳转到页面b,再从b页面退回到a页面,
在Android手机中没有问题,a页面正常显示。
在IOS手机中,a页面的提交按钮仍然是置灰状态,不可点击。
分析
Android:
跳转路由再回来后触发了页面刷新,触发componentDidMount等生命周期,按钮状态刷新,重新变为了可点击状态。
ios:
跳转路由再回来,不会触发页面刷新,也不会触发componentDidMount等生命周期,一直保持着跳走之前的状态。
解决方案
初步解决方案:
在跳走之前把按钮状态重新设置为可点击状态。
window.location.href = 'b.html';
setTimeout(() => {//setTimeout解决视觉上按钮状态闪动问题
this.setState({
checkSubmitFlg: true
});
}, 100);
新问题
在网络环境较差情况下,下一个页面还没loading好,所以会先触发setTimeout里的逻辑,导致页面还没跳走,按钮就重新变得可点击了。
尝试的其他解决方案
onpageshow
onpa