欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【AngularJS实现Model缓存的方式】,下面是详细的讲解!
AngularJS实现Model缓存的方式
在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缓存的方式的用户互动如下:
相关问题:angularJs 怎么实现 数字方式的 for 循环
答:用原生的for就可以啊,angularJs里面有个angular.forEach,你可以试试angularJs-forEach{{text}}var test = angular.module('test', []);test.controller('ForEachCtrl', function($scope){var arr = ['A', 'B', 'C'],text = [];angular.forEach... >>详细
相关问题:AngularJS如何判断缓存里是否有用户来进行登录或注销
答:AngularJS一般用来作数据绑定。 你这个需求用JavaScript就可以实现,没必要用其它的框架。 你要明确这个缓存是什么,后端语言是什么。 在页面加载时进行你上面程序的逻辑判断就可以了 >>详细
相关问题:angularjs 全选反选
答:方法如下: 需要用到AngularJS特性:双向数据绑定 注意:没写一行DOM代码!这就是ng的优点,bootstrap.css为了布局,JS代码也只是简单创建ng模块和ng控制器。 效果: 代码如下: 全选/取消全选 全选和取消全选 选择 姓名 操作 Tom 删除 Mary 删... >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【dom】javascript dom追加内容实现示例-追加内容
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【Array】js中更短的 Array 类型转换-类型转换
- 【append】append和appendTo的区别以及appendChil
- 【ExtJs】ExtJs 表单提交登陆实现代码-表单提交-
- 【addClass】javascript自定义的addClass()方法
- 【Event】jquery下为Event handler传递动态参数的
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
