关于AngularJs数据的本地存储详解


Posted in Javascript onJanuary 20, 2017

第一、创建一个factory来储存和调取你的数据(你可以单独创建一个js文件,按照语义命名如:dataService.js。然后在你的主页面引入这个JS文件)

<!--引入到你的主页面里面-->
<script src="dataService.js"></script>
创建一个factory
'use strict';
angular.module('myApp')
.factory('datadService',['$window',function($window) {
 return{ 
 //存储单个属性
  set :function(key,value){
  $window.localStorage[key]=value;
  }, 
  //读取单个属性
  get:function(key,defaultValue){
  return $window.localStorage[key] || defaultValue;
  }, 
  //存储对象,以JSON格式存储
  setObject:function(key,value){
  $window.localStorage[key]=JSON.stringify(value);
  }, 
  //读取对象
  getObject: function (key) {
  return JSON.parse($window.localStorage[key] || '{}');
  }
 }
}]);

第二、将你创建的这个方法模块【datadService】注入到你要控制器中如下的控制器为【productCtrl】,下面我们创建一个set.js文件,里面代码如下:

'use strict';
angular.module('myApp').controller(
 'productCtrl',
 [ '$scope','datadService',
 function($scope, datadService) {
 $scope.appiAppType = 1;
 //这里面$scope.appiAppType的赋值同样可以通过$http.post或者$http.get
 //等方法返回的参数去赋值,例子如下:
 //$http.post('这里是你所要访问的接口【URL】',这里是你想要上传的参数).success(function(data){
   // $scope.appiAppType = data;
   //});
 datadService.setObject("lodinData", $scope.appiAppType);// 将你获取来的数据存储到你之前创建的【datadService】中,这里面的【lodinData】是KEY(个人理解就是你把数据存到大箱子里面这个箱子就是【datadService】,为了方便在这个箱子里面更好的寻找你想要的数据就给他一个小标签,那就是【lodinData】)
 } ]);

第三、关于存储好的数据如何在不同的控制其中获取到,下面我们创建一个get.js,里面代码如下:

'use strict';
//首先大家要把之前创建好的模块也就是那个装数据的箱子【datadService】放到这个控制器中(也就是模块注入)
//其次大家通过之前咱们设定的标签【lodinData】,用【getObject('key')】方法取到你想要的数据;
//具体实现就一行代码:datadService.getObject('lodinData');「注:把箱子拿出来(datadService)用(getObject)去拿你的这个(lodinData)标签下的数据」
angular.module('myApp').controller(
 'completeCtrl',
 [ '$scope', 'datadService',
 function($scope, datadService) {
 //我们这里取到来上面已经存好的数据:【datadService.getObject('lodinData');】并且把这个数据赋值给了【$scope.LoginList】
 $scope.LoginList = datadService.getObject('lodinData');
 //这里大家可以打印一下$scope.LoginList 看看里面是什么;
 alert(JSON.stringify($scope.LoginList))
 } ]);

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
Javascript单元测试框架QUnitjs详细介绍
May 08 Javascript
jquery ajax请求方式与提示用户正在处理请稍等
Sep 01 Javascript
Node.js中安全调用系统命令的方法(避免注入安全漏洞)
Dec 05 Javascript
javascript实现可全选、反选及删除表格的方法
May 15 Javascript
微信小程序 教程之模板
Oct 18 Javascript
JavaScript实现分页效果
Mar 28 Javascript
详解AngularJS之$window窗口对象
Jan 17 Javascript
在vue项目中使用Nprogress.js进度条的方法
Jan 31 Javascript
JS实现的合并多个数组去重算法示例
Apr 11 Javascript
微信小程序中使用ECharts 异步加载数据实现图表功能
Jul 13 Javascript
详解vue更改头像功能实现
Apr 28 Javascript
jQuery实现B2B网站后台管理系统侧导航
Jul 08 jQuery
html5 canvas 详细使用教程
Jan 20 #Javascript
canvas绘制万花筒效果(代码分享)
Jan 20 #Javascript
原生js实现网页顶部自动下拉/收缩广告效果
Jan 20 #Javascript
Angular.js中ng-if、ng-show和ng-hide的区别介绍
Jan 20 #Javascript
轻松理解Javascript变量的相关问题
Jan 20 #Javascript
js+css3实现旋转效果
Jan 20 #Javascript
Bootstrap 手风琴菜单的实现代码
Jan 20 #Javascript
You might like
第七节--类的静态成员
2006/11/16 PHP
php 邮件发送问题解决
2014/03/22 PHP
WordPress中给媒体文件添加分类和标签的PHP功能实现
2015/12/31 PHP
PHP排序算法之希尔排序(Shell Sort)实例分析
2018/04/20 PHP
Jquery性能优化详解
2014/05/15 Javascript
JavaScript eval() 函数介绍及应用示例
2014/07/29 Javascript
node.js中的path.isAbsolute方法使用说明
2014/12/08 Javascript
写给小白的JavaScript引擎指南
2015/12/04 Javascript
JavaScrip常见的一些算法总结
2015/12/28 Javascript
jQuery制作图片旋转效果
2017/02/02 Javascript
使用原生的javascript来实现轮播图
2017/02/24 Javascript
将input框中输入内容显示在相应的div中【三种方法可选】
2017/05/08 Javascript
详解webpack异步加载业务模块
2017/06/23 Javascript
angular使用bootstrap方法手动启动的实例代码
2017/07/18 Javascript
微信小程序之选项卡的实现方法
2017/09/29 Javascript
浅谈React的最大亮点之虚拟DOM
2018/05/29 Javascript
vue图片上传本地预览组件使用详解
2019/02/20 Javascript
vue读取本地的excel文件并显示在网页上方法示例
2019/05/29 Javascript
vue中使用 pako.js 解密 gzip加密字符串的方法
2019/06/10 Javascript
学习LayUI时自研的表单参数校验框架案例分析
2019/07/29 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
解决VantUI popup 弹窗不弹出或无蒙层的问题
2020/11/03 Javascript
[01:02:32]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第二场 2月26日
2021/03/11 DOTA
Python实现的Google IP 可用性检测脚本
2015/04/23 Python
Python的Bottle框架中实现最基本的get和post的方法的教程
2015/04/30 Python
Python处理XML格式数据的方法详解
2017/03/21 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
2020/03/24 Python
python转化excel数字日期为标准日期操作
2020/07/14 Python
使用pygame实现垃圾分类小游戏功能(已获校级二等奖)
2020/07/23 Python
如何用Python编写一个电子考勤系统
2021/02/08 Python
jupyter notebook指定启动目录的方法
2021/03/02 Python
意大利香水和彩妆护肤品购物网站:Ditano
2017/08/13 全球购物
世界上最大的家庭自动化公司:Smarthome
2017/12/20 全球购物
同步和异步有何异同,在什么情况下分别使用他们?举例说明
2014/02/27 面试题
成人大专生实习期的自我评价
2013/10/02 职场文书
职业道德模范事迹材料
2014/08/24 职场文书