이번 글에서는 주로 angularjs의 커스텀 서비스 소개에 대해 이야기합니다. 맞춤형 서비스의 구체적인 사용 예입니다. 이제 이 글을 살펴보겠습니다
맞춤형 서비스를 만드는 3가지 방법
Service
#🎜🎜 #
dao 레이어
: 백그라운드에서 이 레이어의 역할은 데이터베이스와 상호 작용하는 데이터를 작성하는 것입니다. AngleJS에서는 주로 Ajax를 작성하는 데 사용됩니다. .: 주로 논리 코드 작성을 담당하지만, 데이터는 다른 컨트롤러에서 사용하기 위해 AngleJS(데이터 컨테이너 역할)에 유지될 수도 있습니다.
1.factory
#🎜🎜 #factory 메소드에서 생성된 서비스의 기능은 속성과 메소드가 있는 객체를 반환하는 것입니다. var f = myFactory();
<!DOCTYPE html><html><head><meta charset="utf-8"><script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script></head><body><p ng-app="myApp" ng-controller="myCtrl"> <p>{{r}}</p></p><script> //创建模型 var app = angular.module('myApp', []); //通过工厂模式创建自定义服务 app.factory('myFactory', function() { var service = {};//定义一个Object对象' service.name = "张三"; var age;//定义一个私有化的变量 //对私有属性写getter和setter方法 service.setAge = function(newAge){ age = newAge; } service.getAge = function(){ return age; } return service;//返回这个Object对象 }); //创建控制器 app.controller('myCtrl', function($scope, myFactory) { myFactory.setAge(20); $scope.r =myFactory.getAge(); alert(myFactory.name); });</script></body></html>
<script> var app = angular.module('myApp', []); app.factory('myFactory', function($http,$q) { var service = {}; service.name = "张三"; //请求数据 service.getData = function(){ var d = $q.defer(); $http.get("url")//读取数据的函数。 .success(function(response) { d.resolve(response); }) .error(function(){ d.reject("error"); }); return d.promise; } return service; }); app.controller('myCtrl', function($scope, myFactory) { //alert(myFactory.name); myFactory.getData().then(function(data){ console.log(data);//正确时走这儿 },function(data){ alert(data)//错误时走这儿 });; }); </script>
AngularJS 개발 매뉴얼
을 방문하세요.)<p ng-app="myApp" ng-controller="myCtrl"> <h1>{{r}}</h1></p><script> var app = angular.module('myApp', []); app.service('myService', function($http,$q) { this.name = "service"; this.myFunc = function (x) { return x.toString(16);//转16进制 } this.getData = function(){ var d = $q.defer(); $http.get("ursl")//读取数据的函数。 .success(function(response) { d.resolve(response); }) .error(function(){ alert(0) d.reject("error"); }); return d.promise; } }); app.controller('myCtrl', function($scope, myService) { $scope.r = myService.myFunc(255); myService.getData().then(function(data){ console.log(data);//正确时走这儿 },function(data){ alert(data)//错误时走这儿 }); });</script>
<body><p ng-app="myApp" ng-controller="myCtrl"></p><script> var app = angular.module('myApp', []); //需要注意的是:在注入provider时,名字应该是:providerName+Provider app.config(function(myProviderProvider){ myProviderProvider.setName("大圣"); }); app.provider('myProvider', function() { var name=""; var test={"a":1,"b":2}; //注意的是,setter方法必须是(set+变量首字母大写)格式 this.setName = function(newName){ name = newName } this.$get =function($http,$q){ return { getData : function(){ var d = $q.defer(); $http.get("url")//读取数据的函数。 .success(function(response) { d.resolve(response); }) .error(function(){ d.reject("error"); }); return d.promise; }, "lastName":name, "test":test } } }); app.controller('myCtrl', function($scope,myProvider) { alert(myProvider.lastName); alert(myProvider.test.a) myProvider.getData().then(function(data){ //alert(data) },function(data){ //alert(data) }); });</script></body>
<body><p ng-app="myApp"> 在过滤器中使用服务: <h1>{{255 | myFormat}}</h1></p><script> var app = angular.module('myApp', []); app.service('hexafy', function() { this.myFunc = function (x) { return x.toString(16); } }); app.filter('myFormat',['hexafy', function(hexafy) { return function(x) { return hexafy.myFunc(x); }; }]);</script></body>
위 내용은 AngularJS의 맞춤형 서비스에 대한 자세한 설명, 팩토리 사용법, 서비스 및 공급자 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!