angular state sticky true 刷新問題

问题描述:系统有两个导航栏,一个是kendo的menu,另外一个kendo的mobilegroupbutton.

系统已经添加了ui-router-extras相关的js,angular 也设置了sticky:true。

mobilegroupbutton是根据kedo menu的选项来生成的,现在groupbutton里面查找有无当前选项的对象值,

若没有就添加到groupbutton,然后

$state.go(dataItem.widget,{'menuItem':dataItem}, {reload: true});

若存在就直接

$state.go(dataItem.widget,{'menuItem':dataItem});

 

groupbutton也可以导航,用kendo的onselect事件:

 

$scope.onSelect = function(e) {

        

        $state.go(tabButtonValues[e.index].widget,{'menuItem':tabButtonValues[e.index]});

        $scope.tempMenuItem=tabButtonValues[e.index];

 

  };

 

 

问题分析:

若一直使用menu导航,每个页面的状态都可以保留,无刷新;

若一直使用groupbutton导航,每个页面的状态也可以保留,无刷新;

但是两者交替使用,就会出现页面的刷新问题。比较两者的不同:

$state.go(dataItem.widget,{'menuItem':dataItem});

$state.go(tabButtonValues[e.index].widget,{'menuItem':tabButtonValues[e.index]});

 

两者唯一不同就是参数‘menuItem’的值,问题找到了,因在根据menu产生groupbutton时,没有将整个menu里的item值赋值给groupbutton,导致,交替导航时传输的参数对象不完全一样。

 

总结:若要使状态都保持不变,出来url是一样,参数对象也必须一致。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值