您的位置:首页 > 其它

ionic后退造成的闪退解决方案

2017-07-10 12:59 169 查看
闪退问题造成的原因,经过试验分析,结果发现是历史记录和ionic内部的缓存机制造成的。如果设置启用缓存机制,那么一些路由就会被记录在历史记录中,但有些模块未启用缓存机制,无法正常跳转,于是在返回的时候,造成了无法识别上一页,造成了闪退。适用 v.1.3.2 版本,仅供参考。

后退实现的机制

分平台来实现,关键代码:

// 返回功能
function back() {
$ionicViewSwitcher.nextDirection('back');
ionic.Platform.isIOS() ? $ionicHistory.goBack() : $ionicNativeTransitions.goBack();  // 分平台处理
}


设置清理功能

在tab栏的每个根节点的模块下,比如tab栏下的首页,分类,广场,个人这些模块,如下:



举例在首页模块的controller中添加视图事件,关键代码如下:

// 添加视图事件
$scope.$on('$ionicView.beforeEnter', function(){
$ionicHistory.clearHistory();
});


测试并添加最后解决方案

测试是否还存在因后退而闪退功能,如果还存在问题,检查出现问题的页面,关闭view层的缓存机制。

<ion-view cache-view="false"></ion-view>


如上代码,
cache-view
属性设置为
false


通过上述方法,问题解决。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: