AngularJS实现Model缓存的方式

 更新时间:2016年02月03日 08:59:06   作者:Darren Ji  
这篇文章主要介绍了AngularJS实现Model缓存的方式,分享了多种AngularJS实现Model缓存的方法,感兴趣的小伙伴们可以参考一下

GPT4.0+Midjourney绘画+国内大模型 会员永久免费使用!
如果你想靠AI翻身,你先需要一个靠谱的工具!

在AngularJS中如何实现一个Model的缓存呢?

可以通过在Provider中返回一个构造函数,并在构造函数中设计一个缓存字段,在本篇末尾将引出这种做法。

一般来说,Model要赋值给Scope的某个变量。

有的直接把对象赋值给Scope变量;有的在Provider中返回一个对象再赋值给Scope变量;有的在Provider中返回一个构造函数再赋值给Scope变量。本篇来一一体验。

首先自定义一个directive,用来点击按钮改变一个scope变量值。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
angular
 .module('app',[])
 .directive('updater', function(){
  reutrn {
   scope: {
    user: '='
   },
   template: '<button>Change User.data to whaaaat?</button>',
   link: function(scope, element, attrs){
    element.on('click', function(){
     scope.user.data = 'whaaaat?';
     scope.$apply();
    })
   }
  }

■ 给Scope变量赋值一个对象

1
2
3
4
5
6
7
8
.controller('FirstCtrl', function(){
 var first = this;
 first.user = {data: 'cool'};
})
.controller('SecondCtrl', function(){
 var second = this;
 second.user = {data: 'cool'};
})

页面中:

1
2
3
4
5
6
7
8
9
10
11
<div ng-controller="FirstCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>
 
<div ng-controller="SecondCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>

以上,

  • ● 改变FirstCtrl中input的值,仅仅影响FirstCtrl中的变量user,不影响SecondCtrl中的变量user
  • ● 点击FirstCtrl中的按钮,仅仅影响FirstCtrl中的变量user
  • ● 改变SecondCtrl中的input的值,仅仅影响SecondCtrl中的变量user,不影响FirstCtrl中的变量user
  • ● 点击SecondCtrl中的按钮,仅仅影响SecondCtrl中的变量user

■ 在Provider返回一个对象,赋值给Scope变量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
.controller('ThirdCtrl',['User', function(User){
 var third = this;
 third.user = User;
}])
.controller('FourthCtrl', ['User',function(User){
 var fourth = this;
 fourth.user = User;
}])
//provider返回对象
.provider('User', function(){
 this.$get = function(){
  return {
   data: 'cool'
  }
 };
})

页面中:

1
2
3
4
5
6
7
8
9
10
11
<div ng-controller="ThirdCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>
 
<div ng-controller="FourthCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>

以上,

  • ● 改变ThirdCtrl中input的值,同时影响ThirdCtrl和FourthCtrl中的变量user
  • ● 点击ThirdCtrl中的按钮,同时影响ThirdCtrl和FourthCtrl中的变量user
  • ● 改变FourthCtrl中input的值,同时影响ThirdCtrl和FourthCtrl中的变量user
  • ● 点击FourthCtrl中的按钮,同时影响ThirdCtrl和FourthCtrl中的变量user

■ 在Provider中返回一个构造函数,赋值给Scope变量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
.controller('FifthCtrl',['UserModel', function(UserModel){
 var fifth = this;
 fifth.user = new UserModel();
}])
.controller('SixthCtrl',['UserModel', function(UserModel){
 var sixth = this;
 sixth.user = new UserModel();
}])
//provider返回构造函数,每一次构造,就生成一个实例
.provider('UserModel', function(){
 this.$get = function(){
  return function(){
   this.data = 'cool';
  }
 }
})

页面中:

1
2
3
4
5
6
7
8
9
10
11
<div ng-controller="FifthCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>
 
<div ng-controller="SixthCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>

以上,

  • ● 改变FifthCtrl中input的值,仅仅影响FifthCtrl中的变量user,不影响SixthCtrl中的变量user
  • ● 点击FifthCtrl中的按钮,仅仅影响FifthCtrl中的变量user
  • ● 改变SixthCtrl中的input的值,仅仅影响SixthCtrl中的变量user,不影响FifthCtrl中的变量user
  • ● 点击SixthCtrl中的按钮,仅仅影响SixthCtrl中的变量user

■ 在Provider中返回一个构造函数,带缓存字段,赋值给Scope变量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
.controller('SeventhCtrl',['SmartUserModel', function(SmartUserModel){
 var seventh = this;
 seventh.user = new SmartUserModel(1);
}])
.controller('EighthCtrl',['SmartUserModel', function(SmartUserModel){
 var eighth = this;
 eighth.user = new SmartUserModel(1);
}])
//provider返回构造函数,根据id获取,如果第一次就创建一个放缓存字段中,以后从缓存中获取
.provider('SmartUserModel', function(){
 this.$get = ['$timeout', function($timeout){
  var User = function User(id){
   //先从缓存字段提取
   if(User.cached[id]){
    return User.cached[id];
   }
   this.data = 'cool';
   User.cached[id] = this;
  };
   
  User.cached = {};
  return User;
 }];
})

页面中:

1
2
3
4
5
6
7
8
9
10
11
<div ng-controller="SeventhCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>
 
<div ng-controller="EighthCtrl">
 {{user.data}}
 <input ng-model="user.data">
 <div updater user="user"></div>
</div>

以上,

  • ● 改变SeventhCtrl中input的值,同时影响SeventhCtrl和EighthCtrl中的变量user
  • ● 点击SeventhCtrl中的按钮,同时影响SeventhCtrl和EighthCtrl中的变量user
  • ● 改变EighthCtrl中input的值,同时影响SeventhCtrl和EighthCtrl中的变量user
  • ● 点击EighthCtrl中的按钮,同时影响SeventhCtrl和EighthCtrl中的变量user

以上就是本文的全部内容,希望对大家的学习有所帮助。

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

相关文章

  • AngularJS实现自定义指令与控制器数据交互的方法示例

    AngularJS实现自定义指令与控制器数据交互的方法示例

    这篇文章主要介绍了AngularJS实现自定义指令与控制器数据交互的方法,结合具体实例形式分析了AngularJS自定义指令的实现以及与控制器数据交互的操作技巧,需要的朋友可以参考下
    2017-06-06
  • angular4笔记系列之内置指令小结

    angular4笔记系列之内置指令小结

    这篇文章主要介绍了angular4笔记系列之内置指令小结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • Angular实现点击按钮控制隐藏和显示功能示例

    Angular实现点击按钮控制隐藏和显示功能示例

    这篇文章主要介绍了Angular实现点击按钮控制隐藏和显示功能,结合实例形式分析了AngularJS简单控制页面元素显示与隐藏的相关操作技巧,需要的朋友可以参考下
    2017-12-12
  • AngularJS中update两次出现$promise属性无法识别的解决方法

    AngularJS中update两次出现$promise属性无法识别的解决方法

    最近在工作中用AngularJS中update了两次之后发现$promise属性无法识别了,后来通过查找相关的资料终于解决了,想着记录下方便自己或者有需要的朋友,所以本文主要介绍了AngularJS中update两次出现了$promise属性无法识别的解决方法,需要的朋友可以参考借鉴。
    2017-01-01
  • Angular中懒加载模块初始化技术实例解析

    Angular中懒加载模块初始化技术实例解析

    这篇文章主要为大家介绍了Angular中懒加载模块初始化技术实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Angularjs material 实现搜索框功能

    Angularjs material 实现搜索框功能

    这篇文章主要介绍了Angularjs material 实现搜索框功能的相关资料,需要的朋友可以参考下
    2016-03-03
  • 使用AngularJS对路由进行安全性处理的方法

    使用AngularJS对路由进行安全性处理的方法

    这篇文章主要介绍了使用AngularJS对路由进行安全性处理的方法,AngularJS是一款高人气的JavaScript库,需要的朋友可以参考下
    2015-06-06
  • AngularJS入门教程一:路由用法初探

    AngularJS入门教程一:路由用法初探

    这篇文章主要介绍了AngularJS路由用法,简单分析了AngularJS路由的概念、功能及基本使用方法,需要的朋友可以参考下
    2017-05-05
  • Angularjs 基础入门

    Angularjs 基础入门

    这篇文章主要介绍了Angularjs 基础入门的一些知识,需要的朋友可以参考下
    2014-12-12
  • 利用Ionic2 + angular4实现一个地区选择组件

    利用Ionic2 + angular4实现一个地区选择组件

    ionic是一个移动端开发框架,使用hybird技术,只要使用前端开发技术就可以开发出电脑端,安卓端和ios端的站点程序。下面这篇文章主要给大家介绍了关于利用Ionic2 + angular4实现一个地区选择组件的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-07-07

最新评论