AngularJS實現Model緩衝的方式_AngularJS

來源:互聯網
上載者:User

在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

以上就是本文的全部內容,希望對大家的學習有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.