在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>
以上,
■ 在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>
以上,
■ 在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>
以上,
■ 在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>
以上,
以上就是本文的全部内容,希望对大家的学习有所帮助。
本文地址:https://www.stayed.cn/item/5185
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我