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
以上就是本文的全部内容,希望对大家的学习有所帮助。
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
相关文章
AngularJS中update两次出现$promise属性无法识别的解决方法
最近在工作中用AngularJS中update了两次之后发现$promise属性无法识别了,后来通过查找相关的资料终于解决了,想着记录下方便自己或者有需要的朋友,所以本文主要介绍了AngularJS中update两次出现了$promise属性无法识别的解决方法,需要的朋友可以参考借鉴。2017-01-01
最新评论