麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

AngularJS基于factory創建自定義服務的方法詳解

2019-11-19 16:29:17
字體:
來源:轉載
供稿:網友

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

為什么要創建自定義服務?

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

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

例子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來創建一個服務和創建一個控制器非常像,只是創建服務需要返回這個服務的對象。這里的對象就是NameFactory 。一般的寫法是在函數的一開始就創建一個變量對象,而后在進行對象里面屬性以及方法的設置,最后返回這個對象即可。

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

自定義服務還有個更強大的玩法,就是在創建自定義服務的同時將已經創建好的服務注入。以上一篇博文的基礎為例,使用自定義服務來實現讀取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">沒有數據</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數據</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 注入到匿名函數中。
2)創建一個變量對象,命名為loadJson。
3)在該對象中創建一個方法,命名為loadjson()。
4)創建一個變量d,賦予它$q.difer()方法。
5)使用http({})創建一個promise對象,并返回該promise對象。
6)返回ladJson對象。服務創建完畢。
7)在控制器中注入該服務,使用then()方法對自定義服務返回的承諾進行操作。

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲精品午夜视频 | 国产亚洲精久久久久久蜜臀 | 99视频有精品视频高清 | 国产亚洲小视频 | vidz 98hd| 久久sp | 黄视频免费在线 | 久久久av亚洲男天堂 | 国产成年人在线观看 | 亚洲一区二区国产 | 一区二区精品视频在线观看 | 日本精品视频一区二区三区四区 | 羞羞视频免费网站 | 视频一区国产精品 | 性大片性大片免费 | 久色视频网站 | 一边吃奶一边插下面 | 国产午夜三级一区二区三桃花影视 | 国产精品一区在线看 | 线观看免费完整aaa 久久不雅视频 | 草操视频 | 精品国产一区二区三区久久久蜜月 | 亚洲欧美一区二区三区在线观看 | 国产资源在线播放 | 免费午夜视频 | h色网站免费观看 | 久久91亚洲人成电影网站 | 国产成人自拍av | 日本高清视频网站www | 意大利av在线 | 久草在线新时代视觉 | 久久99精品久久 | 99这里精品 | 91 视频网站| 国产v综合v亚洲欧美久久 | 国产精品91在线 | 精品国产一区二区久久 | 国产精品剧情一区二区在线观看 | 欧美日韩在线免费观看 | 99精品热视频 | 久久综合婷婷香五月 |