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

AngularJS基于factory創(chuàng)建自定義服務的方法詳解

 更新時間:2017年05月25日 14:25:10   作者:面具哥布林  
這篇文章主要介紹了AngularJS基于factory創(chuàng)建自定義服務的方法,結合實例形式分析了AngularJS使用factory創(chuàng)建自定義服務的具體步驟、操作技巧與相關注意事項,需要的朋友可以參考下

本文實例講述了AngularJS基于factory創(chuàng)建自定義服務的方法。分享給大家供大家參考,具體如下:

為什么要創(chuàng)建自定義服務?

很簡單,不想讓控制器顯得過于“臃腫”,而且服務可復用。針對性強,每個服務對應不同的功能。

這里介紹如何使用factory創(chuàng)建自定義服務,并且使用他。

例子1:

<!--HTML-->
<div ng-controller="showTheName">
  <h1 ng-bind="name"></h1>
</div>

/*js*/
var app = angular.module("routingDemoApp",[]);
app.factory("showName",function(){
  var NameFactory = {};
  NameFactory.name = "張三";
  return NameFactory;
});
app.controller("showTheName",function($scope,showName){
  $scope.name = showName.name;
});

使用factroy來創(chuàng)建一個服務和創(chuàng)建一個控制器非常像,只是創(chuàng)建服務需要返回這個服務的對象。這里的對象就是NameFactory 。一般的寫法是在函數(shù)的一開始就創(chuàng)建一個變量對象,而后在進行對象里面屬性以及方法的設置,最后返回這個對象即可。

在控制器使用自定義的服務與使用AngularJS自帶的服務幾乎一樣,只是名字的前面沒有美元($)符號。在注入了自定義的服務后,控制器中就可以隨意的使用該控制器返回的對象的屬性和方法了。

自定義服務還有個更強大的玩法,就是在創(chuàng)建自定義服務的同時將已經創(chuàng)建好的服務注入。以上一篇博文的基礎為例,使用自定義服務來實現(xiàn)讀取AJAX文件。(JSON文件可參考前面一篇《AngularJS讀取JSON及XML文件的方法》,這里不給出了)

<!--html-->
<div class="panel panel-default" ng-controller="AjaxJson">
  <div class="panel-body">
    <table class="table table-striped table-hover">
      <thead>
      <tr>
        <td>名</td>
        <td>種類</td>
        <td>價格</td>
        <td>保質期</td>
      </tr>
      </thead>
      <tbody>
      <tr ng-hide="products.length">
        <td colspan="4" class="text-center">沒有數(shù)據(jù)</td>
      </tr>
      <tr ng-repeat="item in products">
        <td ng-bind="item.name"></td>
        <td ng-bind="item.category"></td>
        <td ng-bind="item.price"></td>
        <td ng-bind="item.expiry"></td>
      </tr>
      </tbody>
    </table>
    <p><button ng-click="LoadJson()">加載JSON數(shù)據(jù)</button></p>
  </div>
</div>

/*JS*/
app.factory("loadJSON",function($http,$q){
  var loadJson ={};
  loadJson.loadjson = function(){
    var d = $q.defer();
    $http({
      url:"json.json",
      method:"GET"
    })
      .success(function(response){
      d.resolve(response);
    })
      .error(function(){
        d.reject(alert("出錯"));
      });
    return d.promise;
  };
  return loadJson;
});
app.controller("AjaxJson",function($scope,loadJSON){
  $scope.LoadJson = function () {
    loadJSON.loadjson().then(function(data){
      $scope.products = data;
    },function(){
      alert("出錯");
    })
  }
});

步驟如下:

1)將$http,$q 注入到匿名函數(shù)中。
2)創(chuàng)建一個變量對象,命名為loadJson。
3)在該對象中創(chuàng)建一個方法,命名為loadjson()。
4)創(chuàng)建一個變量d,賦予它$q.difer()方法。
5)使用http({})創(chuàng)建一個promise對象,并返回該promise對象。
6)返回ladJson對象。服務創(chuàng)建完畢。
7)在控制器中注入該服務,使用then()方法對自定義服務返回的承諾進行操作。

更多關于AngularJS相關內容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結》、《AngularJS入門與進階教程》及《AngularJS MVC架構總結

希望本文所述對大家AngularJS程序設計有所幫助。

相關文章

  • angularJs中$scope數(shù)據(jù)序列化的實例

    angularJs中$scope數(shù)據(jù)序列化的實例

    今天小編就為大家分享一篇angularJs中$scope數(shù)據(jù)序列化的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解如何為你的angular app構建一個第三方庫

    詳解如何為你的angular app構建一個第三方庫

    這篇文章主要介紹了詳解如何為你的angular app構建一個第三方庫,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Angular的FormArray和模態(tài)框結合使用實例詳解

    Angular的FormArray和模態(tài)框結合使用實例詳解

    這篇文章主要為大家介紹了Angular的FormArray和模態(tài)框結合使用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • AngularJS 日期格式化詳解

    AngularJS 日期格式化詳解

    AngularJS的日期格式化有兩種形式,一種是在HTML頁面,一種是在JS代碼里,都是用到AngularJS的過濾器$filter
    2015-12-12
  • Angular 2父子組件數(shù)據(jù)傳遞之@ViewChild獲取子組件詳解

    Angular 2父子組件數(shù)據(jù)傳遞之@ViewChild獲取子組件詳解

    這篇文章主要給大家介紹了關于Angular 2父子組件數(shù)據(jù)傳遞之@ViewChild獲取子組件的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • Angularjs 制作購物車功能實例代碼

    Angularjs 制作購物車功能實例代碼

    這篇文章主要介紹了Angularjs 制作購物車功能實例代碼的相關資料,并附示例代碼,需要的朋友可以參考下
    2016-09-09
  • AngularJS輔助庫browserTrigger用法示例

    AngularJS輔助庫browserTrigger用法示例

    這篇文章主要介紹了AngularJS輔助庫browserTrigger用法,結合實例形式分析了輔助庫browserTrigger的功能及單元測試中的使用技巧,需要的朋友可以參考下
    2016-11-11
  • Angular CLI 安裝和使用教程

    Angular CLI 安裝和使用教程

    本篇文章主要介紹了Angular CLI 安裝和使用教程,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • AngularJS 面試題集錦

    AngularJS 面試題集錦

    本文主要介紹AngularJS的面試題資料整理,這里整理了相關面試題的資料,幫助大家學習理解AngularJS的知識,有興趣的小伙伴可以參考下
    2016-09-09
  • AngularJS表單驗證中級篇(3)

    AngularJS表單驗證中級篇(3)

    這篇文章主要為大家詳細介紹了AngularJS表單驗證,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評論