加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 更改$ionicHistory.backView()的stateParams之后返

发布时间:2020-12-17 07:10:28 所属栏目:安全 来源:网络整理
导读:我正在使用Ionic Framework开发一个 Android应用程序. 在那里,我有三个视图,view1,view2和view3. 导航将像view1 – view2 – VIEW3 从view3移回view2时,我需要更改view2的stateParam param1值来执行某些操作.下面的代码显示我在view3中单击后退按钮时更改了v
我正在使用Ionic Framework开发一个 Android应用程序.

在那里,我有三个视图,view1,view2和view3.

导航将像view1 – > view2 – > VIEW3

从view3移回view2时,我需要更改view2的stateParam param1值来执行某些操作.下面的代码显示我在view3中单击后退按钮时更改了view2的stateParam值

以下是覆盖Android设备backbutton动作的代码

$ionicPlatform.registerBackButtonAction(function() {

      if ($state.current.name == "view3") {
          $ionicHistory.backView().stateParams = {param1:true};
          $ionicHistory.goBack(); // moves to view2
      } else {
          $ionicHistory.goBack();
      }

},100);

回到view2后,如果我现在单击后退按钮,它将移至view3而不是view1.现在我只能通过单击后退按钮来查看view3和view2,而不是移动到view1.

如何使后退按钮从view2移动到view1甚至在更改view2的stateParam值后?

解决方法

我终于找到了解决这个问题的方法,不幸的是,这是一个黑客,所以它有点难看.

提示不仅要更新stateParams,还要更新stateId.

请看下面一个可重复使用的答案:

var params = {param1:true};
var backView = $ionicHistory.backView();

var stateId = backView.stateName;
for (var key in params) {
    if (params[key] && params[key] !== "") {
        stateId += "_" + key + "=" + params[key];
    }
}

backView.stateParams = params;
backView.stateId = stateId;
$ionicHistory.goBack();

在您的具体情况下,它可能只是:

if ($state.current.name == "view3") {
    var backView = $ionicHistory.backView();
    backView.stateParams = {param1:true};
    backView.stateId = backView.stateName + "_param1=true";
    $ionicHistory.goBack(); // moves to view2
} else {
    $ionicHistory.goBack();
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读