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

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

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

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

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

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变量赋值一个对象

    .controller('FirstCtrl', function(){
var first = this;
first.user = {data: 'cool'};
})
.controller('SecondCtrl', function(){
var second = this;
second.user = {data: 'cool'};
})

页面中:

<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变量

    .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'
}
};
})

页面中:

<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变量

    .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';
}
}
})

页面中:

<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变量

    .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;
}];
})

页面中:

<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

AngularJS中实现Model缓存的更多相关文章

  1. AngularJS中的$http缓存以及处理多个$http请求

    在AngularJS的实际项目中,经常需要处理多个$http请求,每个$http请求返回一个promise,我们可以把多个promise放到$q.all()方法接受的一个数组实参中去. ■ 处理多个$ ...

  2. Angularjs中的缓存以及缓存清理

    写在最前面:这篇博文是2篇文章组成,详细介绍了Angularjs中的缓存以及缓存清理,文章由上海尚学堂转载过来,欢迎大家阅读和评论.转载请注明出处,谢谢! 一个缓存就是一个组件,它可以透明地储存数据, ...

  3. AngularJS中实现无限级联动菜单

    多级联动菜单是常见的前端组件,比如省份-城市联动.高校-学院-专业联动等等.场景虽然常见,但仔细分析起来要实现一个通用的无限分级联动菜单却不一定像想象的那么简单.比如,我们需要考虑子菜单的加载是同步的 ...

  4. AngularJS 中的 Promise 和 设计模式(转)

    原文地址:http://my.oschina.net/ilivebox/blog/293771 目录[-] Promise 简单例子 链式 Promise Parallel Promises And ...

  5. AngularJS 中的 Promise 和 设计模式

    解决 Javascript 异步事件的传统方式是回调函数:调用一个方法,然后给它一个函数引用,当这个方法完结的时候执行这个函数引用. <!-- lang: js --> $.get('ap ...

  6. 浅谈AngularJS中的$parse和$eval

    AngularJS的初学者常常会对$parse和$eval两个内建服务感到有些困惑,今天我们就来说说AngularJS中的$parse和$eval. 总的来说,$parse和$eval都是作用于Ang ...

  7. AngularJS中的指令

    欢迎大家讨论与指导 : )  前言 当AngularJS中的内置指令不能满足我们的需求,或者当我们需要创建一个能够用于多个AngularJS程序的自包含的功能单元时,我们应该创建自定义指令来满足需求. ...

  8. AngularJS中实现无限级联动菜单(使用demo)

    昨天没来得及贴几个使用demo,今天补上,供有兴趣的同学参考 :) 1. 同步加载子选项demo2. 异步加载子选项demo3. 初始值回填demo4. 倒金字塔依赖demo directive的源代 ...

  9. AngularJS学习--- AngularJS中模板链接和图像 ng-src step6

    接上一篇文章,本文将主要介绍angularjs中的模板链接,和图像显示? 首先,切换分支,启动项目: git checkout step- npm start 1.效果 相较于前一篇文章,明显感觉多了 ...

随机推荐

  1. 目标检测--SSD: Single Shot MultiBox Detector(2015)

    SSD: Single Shot MultiBox Detector 作者: Wei Liu, Dragomir Anguelov, Dumitru Erhan, Christian Szegedy, ...

  2. 根据条件返回相应值 decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

    decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值) [功能]根据条件返回相应值 [参数]c1, c2, ...,cn,字符型/数值型/日期型,必须类型相同或null 注 ...

  3. jQuery性能优化指南

    总是从ID选择器开始继承在jQuery中最快的选择器是ID选择器,因为它直接来自于JavaScript的getElementById()方法. 例如有一段HTML代码:代码 <div id=&q ...

  4. from opencv image to PIL image and reverse

    import cv2 import numpy as np from PIL import Image img = cv2.imread("path/to/img.png") # ...

  5. MySQL CPU 使用率高的原因和解决方法

    用户在使用 MySQL 实例时,会遇到 CPU 使用率过高甚至达到 100% 的情况.本文将介绍造成该状况的常见原因以及解决方法,并通过 CPU 使用率为 100% 的典型场景,来分析引起该状况的原因 ...

  6. python 全栈开发,Day56(jQuery的ajax)

    昨日内容回顾 事件流: 1.事件捕获 从最外层到最内层 2.事件目标阶段 3.事件冒泡 从最内层到最外层 每个事件都会事件对象 event 属性和方法 属性: event.target 目标节点(冒泡 ...

  7. 【C++ Primer 第13章】6.对象移动

    右值引用 左值和右值 (1)两者区别: ①左值:能对表达式取地址.或具名对象/变量.一般指表达式结束后依然存在的持久对象. ②右值:不能对表达式取地址,或匿名对象.一般指表达式结束就不再存在的临时对象 ...

  8. OPENJDK 源码编译

    一.整体编译 我的环境: Ubuntu 16.04 LTS apache-ant-1.8.0-bin.zip 环境变量: export LANG=C export ALT_BOOTDIR=/home/ ...

  9. BZOJ1207 [HNOI2004]打鼹鼠 动态规划

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1207 题目概括 n*n的方阵上,一开始你可以在任何地方. 你每秒可以移动一格,接下来有m只地鼠冒出 ...

  10. BZOJ1192 [HNOI2006]鬼谷子的钱袋 数学推理

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1192 题意概括 把一个数m拆成很多数字. 问至少拆成多少个数字,1~m中的所有数字才可以用这些数字 ...