在AngularJS中如何實現一個Model的緩存呢?可以通過在Provider中返回一個構造函數,併在構造函數中設計一個緩存欄位,在本篇末尾將引出這種做法。一般來說,Model要賦值給Scope的某個變數。有的直接把對象賦值給Scope變數;有的在Provider中返回一個對象再賦值給Scope變
在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