myapp.factory('myHttpService',['$http',function($http){
return {
$http({
url:......
})
}
}])
eq:下一个自定义的http服务
myapp.factory("myHttpService",["$http",function($http){
return {
http:function(url,sfn,efn){
$http({
url:url,
method:"get"
}).success(sfn).error(efn)
}
}
}])
myHttpService.http("http://datainfo.duapp.com/shopdata/getclass.php",function(data){
console.log(data)
},function(data){
console.log(data)
})
2.provider
可以通过去自定义一个服务供应商去定义一个服务,写法有区别,服务功能性的东西需要嵌套一层返回
myapp. provider ('myHttpService',['$http',function($http){
return {
$get:function(){
return:{//这里才是输出
}
}
}])
外面return出来的是这个服务的供应商,供应商的$get方法里返回的才是供我们使用的部分,可以通过更改供应商的部分参数来控制服务的功能,
eq:还是返回一个范围内的随机数,但是通过配置供应商的一个值来控制服务返回的是整数还是小数
myapp.provider("myService",function(){
return {
isInt:true,
$get:function(){
var that=this;
return {
getRandom:function(a,b){
var num=Math.random()*(b-a+1)+a;
if(that.isInt){
return Math.floor(num);
}else{
return(num)
}
}
}
}
}
})
myapp.config(["myServiceProvider",function(myServiceProvider){
myServiceProvider.isInt=false;
}])
通过这种方法创建的服务是可以配置供应商的
3.service
通过这种方法创建出来的只能是对象
最简单的创建方式,自带返回,支持面向对象的写法
myapp.service("myService",function(){
this.getRandom=function(a,b){
return Math.random()*(b-a)+a;
}
})
myapp.service("myService",aaa)
function aaa(){
this.getRandom=function(a,b){
return Math.random()*(b-a)+a;
}
}
多个控制器间数据的共享
实现多个控制器数据共享的方法有这样三种,
第一种比较简单,就是把数据放到父作用域上,就都可以访问了
第二种就是在控制器里通过$$prevSibling找到兄弟作用域,然后使用数据,需要注意的是,如果是初始数据类型的话就不能做数据双向绑定了
第三种是定义服务,把需要共享的数据做成服务,这样就都可以用了
<body>
<div class="container">
<div ng-controller="firstController">
<input type="text" class="form-control" ng-model="name">
<input type="text" class="form-control" ng-model="data.name">
<input type="text" class="form-control" ng-model="Data.name">
<p>
first-name:{{name}}<br>
first-data-name:{{data.name}}<br>
first-Data-name:{{Data.name}}
</p>
</div>
<div ng-controller="secondController">
<p>
second-name:{{name}}<br>
second-data-name:{{data.name}}<br>
second-Data-name:{{Data.name}}
</p>
</div>
</div>
</body>
<script src="../Base/angular.min.js"></script>
<script>
var app=angular.module("myapp",[]);
app.factory("Data",function () {
return {
name:'lily'
}
})
app.controller("firstController",function ($scope,Data) {
$scope.name="allen";
$scope.data={
name:'tom'
}
$scope.Data=Data;
})
app.controller("secondController",function ($scope,Data) {
$scope.name=$scope.$$prevSibling.name;
$scope.data=$scope.$$prevSibling.data;
$scope.Data=Data;
})
</script>
内容版权声明:除非注明,否则皆为本站原创文章。
