欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

AngularJS基于provider實(shí)現(xiàn)全局變量的讀取和賦值方法

 更新時(shí)間:2017年06月28日 10:31:21   作者:小魏的馬仔  
這篇文章主要介紹了AngularJS基于provider實(shí)現(xiàn)全局變量的讀取和賦值方法,結(jié)合實(shí)例形式分析了AngularJS全局變量的聲明、賦值、讀取等相關(guān)使用技巧,需要的朋友可以參考下

本文實(shí)例講述了AngularJS基于provider實(shí)現(xiàn)全局變量的讀取和賦值方法。分享給大家供大家參考,具體如下:

簡單全局變量的設(shè)置

1,通過var 直接定義global variable,這根純js是一樣的。
2,用angularjs value來設(shè)置全局變量 。
3,用angularjs constant來設(shè)置全局變量 。

示例代碼如下:

在app文件中,聲明三種變量

'use strict';
/* App Module */
var test2 = 'tank';     //方法1,定義全局變量
var phonecatApp = angular.module('phonecatApp', [   //定義一個ng-app
 'ngRoute',
 'phonecatControllers',
 'tanktest'
]);
phonecatApp.value('test',{"test":"test222","test1":"test111"}); //方法2定義全局變量
phonecatApp.constant('constanttest', 'this is constanttest');  //方法3定義全局變量

在controller中對全局變量進(jìn)行讀取

'use strict';
/* Controllers */
var phonecatControllers = angular.module('phonecatControllers', []);
phonecatControllers.controller('PhoneListCtrl', ['$scope','test','constanttest',
 function($scope,test,constanttest) {
  $scope.test = test;          //方法2,將全局變量賦值給$scope.test
  $scope.constanttest = constanttest;  //方法3,賦值
  $scope.test2 = test2;         //方法1,賦值
 }]);

注意事項(xiàng)

var test;設(shè)置后,無需在controller聲明的時(shí)候注入,直接使用即可。

value和contant,在app中初始化后,需要在controller聲明時(shí)候注入到controller中,才能夠使用。

這三種方式都存在一個問題,即只能夠讀取全局變量,無法對全局變量進(jìn)行修改賦值。在很對業(yè)務(wù)邏輯中無法滿足業(yè)務(wù)需求。

使用provider實(shí)現(xiàn)全局變量。

步驟與上面的value和contant差不多。

在app中完成聲明和初始化。

<script type="text/javascript">
    var app = angular.module('ngRouteWxCtb', ['ngRoute','ngCookies']);
    //TODO:provider of globle uid and weixinIsInit param
    app.provider('userService', function () {
      var data = {uid:0,weixinIsInit:false};
      var f = function (uid,weixinIsInit) {
        if (uid != 0)
        {
          data.uid= uid;
          data.weixinIsInit = weixinIsInit;
        }
        return data;
      };
      this.$get = function () {
        return f;
      };
    });
</script>

在controller聲明的時(shí)候,注入。

app.controller('myCtrl1', function ($scope, userService) {
  var data = userService(0, 0, false);//讀取全局變量
}));
app.controller('myCtrl2', function ($scope, userService) {
  var data = userService(123, 111, true);//設(shè)置全局變量
}));

通過provider提供的get方法,實(shí)現(xiàn)參數(shù)的讀取和賦值。

注意事項(xiàng)

代碼中,我們對provider 的賦值操作進(jìn)行了取巧設(shè)計(jì),當(dāng)?shù)谝粋€參數(shù)等于0的時(shí)候,默認(rèn)是讀取,當(dāng)?shù)谝粋€參數(shù)不為0的時(shí)候,實(shí)現(xiàn)的是設(shè)置后進(jìn)行讀取。這樣,公用一個get方法即可,無需增加新的方法。

更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)

希望本文所述對大家AngularJS程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • AngularJS 自定義過濾器詳解及實(shí)例代碼

    AngularJS 自定義過濾器詳解及實(shí)例代碼

    這篇文章主要介紹了AngularJS 自定義過濾器,這里整理了相關(guān)資料及示例代碼,有興趣的小伙伴可以參考下
    2016-09-09
  • AngularJS利用Controller完成URL跳轉(zhuǎn)

    AngularJS利用Controller完成URL跳轉(zhuǎn)

    本文的主要內(nèi)容是介紹在AngularJS中怎樣利用Controller實(shí)現(xiàn)URL跳轉(zhuǎn),本文給出了實(shí)例代碼,簡單明了,有需要的可以參考學(xué)習(xí)。
    2016-08-08
  • AngularJS 模塊詳解及簡單實(shí)例

    AngularJS 模塊詳解及簡單實(shí)例

    本文主要介紹AngularJS 模塊,這里幫大家整理了相關(guān)資料,詳細(xì)介紹了AngularJS的基礎(chǔ)知識,有需要的朋友可以參考下
    2016-07-07
  • Angular2+如何去除url中的#號詳解

    Angular2+如何去除url中的#號詳解

    這篇文章主要給大家介紹了關(guān)于Angular 2+時(shí)如何去除url中#號的相關(guān)資料,文中先對#號去除的原因及方法進(jìn)行詳細(xì)的介紹和分析,然后通過示例代碼給大家演示去除的方法,需要的朋友可以參考借鑒,下面隨著小編來一起看看吧。
    2017-12-12
  • 詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程

    詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程

    本篇文章主要介紹了詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程 ,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • Angular 2應(yīng)用的8個主要構(gòu)造塊有哪些

    Angular 2應(yīng)用的8個主要構(gòu)造塊有哪些

    這篇文章主要為大家詳細(xì)介紹了Angular 2應(yīng)用的8個主要構(gòu)造塊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • 詳解AngularJS 模態(tài)對話框

    詳解AngularJS 模態(tài)對話框

    在涉及GUI程序開發(fā)的過程中,常常有模態(tài)對話框以及非模態(tài)對話框的概念。接下來通過本文給大家介紹AngularJS 模態(tài)對話框 ,感興趣的朋友一起學(xué)習(xí)吧
    2016-04-04
  • 簡單談?wù)剅equire模塊化jquery和angular的問題

    簡單談?wù)剅equire模塊化jquery和angular的問題

    下面小編就為大家?guī)硪黄唵握務(wù)剅equire模塊化jquery和angular的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 詳解AngularJS中的filter過濾器用法

    詳解AngularJS中的filter過濾器用法

    這篇文章主要介紹了AngularJS中的filter過濾器用法,包括其在模版中和在controller以及service的常見應(yīng)用場合,需要的朋友可以參考下
    2016-01-01
  • 使用angular寫一個hello world

    使用angular寫一個hello world

    這篇文章主要介紹了使用angular寫一個hello world的方法及示例,需要的朋友可以參考下
    2015-01-01

最新評論