在 AngularJs 中清除服务数据

Posted

技术标签:

【中文标题】在 AngularJs 中清除服务数据【英文标题】:Clear service data in AngularJs 【发布时间】:2014-06-21 19:58:47 【问题描述】:

我正在尝试将数据存储在我的服务中,类似于:

Processing $http response in service

app.factory('myService', function($http) 变种承诺; 变量我的服务 = 异步:函数() 如果(!承诺) // $http 返回一个promise,它有一个then函数,它也返回一个promise promise = $http.get('test.json').then(function (response) // 这里的then函数是修改响应的机会 控制台日志(响应); // 返回值由控制器中的 then 获取。 返回响应。数据; ); // 将承诺返回给控制器 回报承诺; ; 返回我的服务; ); app.controller('MainCtrl', function(myService,$scope) $scope.clearData = 函数() $scope.data = ; ; $scope.getData = 函数() // 调用异步方法,然后处理我们自己的 then 函数中返回的内容 myService.async().then(function(d) $scope.data = d; ); ; );

但是,我注意到我的服务中的数据即使在注销后仍然存在。因此,我可以以完全不同的用户身份登录并查看我不应该看到的数据。

注销后如何清除数据?当然,我可以手动清除所有服务中的所有内容,但我正在寻找更通用的方法,例如“清除所有用户数据”。我试图强制刷新页面,它可以工作,但我不喜欢它产生的闪存。

编辑:示例代码

【问题讨论】:

如何究竟“相似”呢? (即显示你的代码)如果你做得对,你真的不应该在服务中有任何持久性数据。 你能分享你的服务代码吗? 我应该重新表述我的问题,注销是指我自己的注销功能,它只是删除了一些用户数据。服务仍然被实例化,并且包含与注销之前相同的内容。 您引用的示例不保存数据。你是如何保存数据的?通过缓存?在服务上的 var 中? 作为服务上的承诺/变量,我会将示例中的代码添加到问题中。 【参考方案1】:

要清除 myService 中的数据,您可能需要在 $scope.clearData 上调用 destroy() 函数。 例如:

app.factory('myService',function('$http')
   /// do you stuff
   return
     myServices : //...,
     destroy : function()
       promise = null;//destroy promise
     
   
);

附带说明,您可能不想将数据存储在 $scope 中。您可能希望将控制和数据分开。

【讨论】:

【参考方案2】:

我正在使用 angular-devise 来管理我的用户。以下是我在注销时清除数据的服务:

app.service("MyService", ["$rootScope", function($rootScope) 
  // destroy the user data on logout
  self = this;
  this.shouldBeDestroyed = "foo";

  $rootScope.$on('devise:logout', function(event) 
    self.shouldBeDestroyed = null;
  );
);

我很想找到一种更可靠的方法来销毁服务中的敏感对象。不过这解决了我的问题。

【讨论】:

以上是关于在 AngularJs 中清除服务数据的主要内容,如果未能解决你的问题,请参考以下文章

AngularJS $http 之 POST 传参

初识AngularJS

angularjs 学习笔记

在AngularJS中清除工厂状态变化的最佳实践(1.x)

AngularJS的学习笔记

从使用 AngularJS 开发的网站获取数据访问权限