AngularJS入门教程之服务(Service)
AngularJS服务(Service)
AngularJS中你可以创建自己的服务,或使用内建服务。
什么是服务?
在AngularJS中,服务是一个函数或对象,可在你的AngularJS应用中使用。
AngularJS内建了30多个服务。
有个$location服务,它可以返回当前页面的URL地址。
实例
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>当前页面的url:</p>
<h3>{{myUrl}}</h3>
</div>
<p>该实例使用了内建的$location服务获取当前页面的URL。</p>
<script>
varapp=angular.module('myApp',[]);
app.controller('myCtrl',function($scope,$location){
$scope.myUrl=$location.absUrl();
});
</script>
</body>
</html>
运行结果:
当前页面的url:
http://www.runoob.com/try/try.php?filename=try_ng_services
该实例使用了内建的$location服务获取当前页面的URL。
注意:$location服务是作为一个参数传递到controller中。如果要使用它,需要在controller中定义。
为什么使用服务?
$http是AngularJS应用中最常用的服务。服务向服务器发送请求,应用响应服务器传送过来的数据。
AngularJS会一直监控应用,处理事件变化,AngularJS使用$location服务比使用window.location对象更好。
$http服务
$http是AngularJS应用中最常用的服务。服务向服务器发送请求,应用响应服务器传送过来的数据。
实例
使用$http服务向服务器请求数据:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>欢迎信息:</p>
<>{{myWelcome}}<>
</div>
<p>$http服务向服务器请求信息,返回的值放入变量"myWelcome"中。</p>
<script>
varapp=angular.module('myApp',[]);
app.controller('myCtrl',function($scope,$http){
$http.get("welcome.htm").then(function(response){
$scope.myWelcome=response.data;
});
});
</script>
运行结果:
欢迎信息:
欢迎访问
$http服务向服务器请求信息,返回的值放入变量"myWelcome"中。
以上是一个非常简单的$http服务实例,更多$http服务应用请查看AngularJSHttp教程。
$timeout服务
AngularJS$timeout服务对应了JSwindow.setTimeout函数。
实例
两秒后显示信息:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>两秒后显示信息:</p>
<h1>{{myHeader}}</h1>
</div>
<p>$timeout访问在规定的毫秒数后执行指定函数。</p>
<script>
varapp=angular.module('myApp',[]);
app.controller('myCtrl',function($scope,$timeout){
$scope.myHeader="HelloWorld!";
$timeout(function(){
$scope.myHeader="Howareyoutoday?";
},2000);
});
</script>
</body>
</html>
运行结果:
两秒后显示信息:
Howareyoutoday?
$timeout访问在规定的毫秒数后执行指定函数。
$interval服务
AngularJS$interval服务对应了JSwindow.setInterval函数。
实例
每两秒显示信息:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>现在时间是:</p>
<h1>{{theTime}}</h1>
</div>
<p>$interval访问在指定的周期(以毫秒计)来调用函数或计算表达式。</p>
<script>
varapp=angular.module('myApp',[]);
app.controller('myCtrl',function($scope,$interval){
$scope.theTime=newDate().toLocaleTimeString();
$interval(function(){
$scope.theTime=newDate().toLocaleTimeString();
},1000);
});
</script>
</body>
</html>
运行效果:
现在时间是:
下午3:41:09
$interval访问在指定的周期(以毫秒计)来调用函数或计
创建自定义服务
你可以创建自定义的访问,链接到你的模块中:
创建名为hexafy的访问:
app.service('hexafy',function(){
this.myFunc=function(x){
returnx.toString(16);
}
});
要使用自定义的访问,需要在定义过滤器的时候独立添加:
实例
使用自定义的的服务hexafy将一个数字转换为16进制数:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>255的16进制是:</p>
<h1>{{hex}}</h1>
</div>
<p>自定义服务,用于转换16进制数:</p>
<script>
varapp=angular.module('myApp',[]);
app.service('hexafy',function(){
this.myFunc=function(x){
returnx.toString(16);
}
});
app.controller('myCtrl',function($scope,hexafy){
$scope.hex=hexafy.myFunc(255);
});
</script>
</body>
</html>
运行结果:
255的16进制是:
ff
自定义服务,用于转换16进制数:
过滤器中,使用自定义服务
当你创建了自定义服务,并连接到你的应用上后,你可以在控制器,指令,过滤器或其他服务中使用它。
在过滤器myFormat中使用服务hexafy:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp">
在过滤器中使用服务:
<h1>{{255|myFormat}}</h1>
</div>
<script>
varapp=angular.module('myApp',[]);
app.service('hexafy',function(){
this.myFunc=function(x){
returnx.toString(16);
}
});
app.filter('myFormat',['hexafy',function(hexafy){
returnfunction(x){
returnhexafy.myFunc(x);
};
}]);
</script>
</body>
</html>
运行效果:
在过滤器中使用服务:
f f
在对象数组中获取值时你可以使用过滤器:
创建服务hexafy:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<divng-app="myApp"ng-controller="myCtrl">
<p>在获取数组[255,251,200]值时使用过滤器:</p>
<ul>
<ling-repeat="xincounts">{{x|myFormat}}</li>
</ul>
<p>过滤器使用服务将10进制转换为16进制。</p>
</div>
<script>
varapp=angular.module('myApp',[]);
app.service('hexafy',function(){
this.myFunc=function(x){
returnx.toString(16);
}
});
app.filter('myFormat',['hexafy',function(hexafy){
returnfunction(x){
returnhexafy.myFunc(x);
};
}]);
app.controller('myCtrl',function($scope){
$scope.counts=[255,251,200];
});
</script>
</body>
</html>
运行效果:
在获取数组[255,251,200]值时使用过滤器:
过滤器使用服务将10进制转换为16进制。
以上就是对AngularJS服务的资料整理,后续继续补充,有需要的朋友参考下。