ionic状态改变时动态(强制)刷新页面

$state.go(stateName,params,config);使用这个方法调到某个状态后,有时需要强制刷新当前页面,使其向后台发起请求,获取最新数据。


1.这种需求的场景举例:


这是处于待办状态(没有被评价的工作记录处于待办状态)的工作记录。

注意:此时待办的工作记录数为45132条



当点击其中一条记录


然后点击评价工作记录对其进行评价


点击评价按钮,评价当前工作记录




评价完成之后,状态就需要跳转至初始页面,并且强制刷新页面,从后台获取数据。

注意:此时待办的工作记录数为45131条,说明刷新成功。



2.实现方式

2.1{reload:true}

强制刷新页面网上资料说使用$state.go("tab.backlog",{},{reload:true}),其中{reload:true}的配置可以实现强制刷新,但是经过我的实验之后发现没有起任何作用。

2.2cache:false

$statePrivider.state({})这个方法中的参数是对象,其中有项属性配置是cache:true/false, ,默认为true。在此,将其配置为false,此时,这个状态就不会有缓存,也就可以实现每次处于该状态时刷新页面,也就相当于实现了强制刷新。(注意:需要继续向下看,很可能此时你任然看不到页面数据被刷新)


如果页面数据是通过$http从后台使用ajax获取的数据,那么页面数据任然得不到刷新。

findPendentRecordList:function(postParams){
    var url =Config.basePath+this.tableName+"/findPendentRecordList.do?callback=JSON_CALLBACK";
    return $http.jsonp(url,{params:postParams});
},

原因在于:在ionic中,$http任何请求默认都是有缓存的,即下面的属性默认是这样配置的

$httpProvider.defaults.cache = true;

也就是说虽然把$state的cache设为了false,他会每次都从后台获取数据,但是$http的cache却为true,那个$http这个偷懒的家伙就会从自己的缓存中拿出数据,而并不会真正的从后台获取,故此,页面数据任然得不到真正的刷新。


看到这里,有人肯定已经想到了解决的办法:将$http的cache设为false,OK,  如愿以偿,万事大吉,效果实现了。

$httpProvider.defaults.cache = false;

但这种设置会把你其他的$http请求的cache一同全部设为false,不好之处在于数据没有缓存,每次需要从后台获取,速度,性能不高。所以,使用另一种方式将需要做强制刷新的$http的请求cache设为false即可,设置方法为:$http.get()或$http.post()或$http.jsonp()等等请求方法中第二个参数是一个对象,在其中添上cache:false的配置。

findPendentRecordList:function(postParams){
    var url =Config.basePath+this.tableName+"/findPendentRecordList.do?callback=JSON_CALLBACK";
    return $http.jsonp(url,{params:postParams,cache:false});
},

总结:

实现强制刷新页面的方式有:

1.{reload:true},目前我没有试验成功。

2.同时将$state和,$http的cache都设为false




看到这里,我相信你的页面已经可以强制刷新了。


2.3动态设置$http的cache

然而,虽然上述方法能达到效果,但不知你有没有发现,随之带来的问题就是每次当路由切换到该状态时,页面都会从后台获取数据。浪费流量、速度慢、用户体验差。

因此,我们需要改变方法。


$state的cache任然设置为false,而$http的cache需要按照需要(例如:上述功能在点击了评价按钮之后,跳转至tab.home状态时设为false,而其他情况下都设为true)动态设置为true OR false。


动态设置的方法:

首先,在state中添加params:{isCache:true},配置项,该项的含义是,这个状态可以接受一个isCache的参数。,默认状态下为true

//代办模块
.state('tab.backlog',{
    url:'/backlog',
    views:{
        'tab-backlog':{
            templateUrl:'templates/backlog/tab-backlog.html',
            controller:'BacklogCtrl'
        }
    },
   cache:false,
    params:{
        isCache:true
    }
})

然后,在使用$state.go()方法转到该状态时,在其第二个参数中加入如下的配置

$state.go("tab.backlog",{isCache:false});


接着,在需要刷新的那个页面controller中使用$stateParams.isCache获取到上面传递的值,并注意,把这个isCache:$stateParams.isCache加到请求参数中

$scope.queryConditions = {
     isCache:$stateParams.isCache
 };

$dataService.findPendentRecordList($scope.queryConditions).success(successCallback);


最后,在$http请求参数中配置上cache属性,其值为刚才你传递过来的请求参数中的isCache的值,此时就能从后台获取数据。

findPendentRecordList:function(postParams){
    var url =Config.basePath+this.tableName+"/findPendentRecordList.do?callback=JSON_CALLBACK";
    return $http.jsonp(url,{params:postParams,cache:postParams.isCache});
},

不需要强制刷新时,就像下面这样切换状态,不配置参数即可。

$state.go("tab.backlog");

因为isCache默认为true

 params:{
        isCache:true
    }


经过一番折腾,虽然路由的cache为false,每次都会从后台获取数据,但是由于$http此时cache咱们给他的默认值为true,所以,实际上$http是从缓存中获取的数据,而并没有真正意义上向后台发送请求。




你可能感兴趣的:(ionic,动态刷新页面,路由状态state改变)