$http服务详解:和ajax原理很像,写法类似

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$http','$timeout',function($scope,$http,$timeout){
	var timer = null;         
	$scope.data = [];
	$scope.change = function(name){
		$timeout.cancel(timer);    // 清除相关的定时器
		timer = $timerout(function(){   // 500毫秒后开启定时器
			$http({
				method : 'JSONP',  // 采用jsonp的方式
				url : 'http://..........?wd = '+ name + '&cb=JSON_CALLBACK'   // 数据传输的地址
			}).success(function(data){
				$scope.name = data.s  // 返回值在data.s下面
			}).error(function(err){
				console.log(err);
			});
		},500);
	}		
}])
<body ng-controller="A">
	<input type="text" ng-model="name" ng-keyup="change(name)">  // 键盘抬起时 触发事件
	<input type="button" value="搜索" ng-click = 'change(name)'> // 点击搜索的时 触发事件
	<ul>
		<li ng-repeat="list in data">{{ list }}</li>
	</ul>
</body>


$location :对原生JS中的location进行封装处理

hash(),path(),search()既可以获取值,也能设置值

port(端口号),host(主机名),protocol(协议)只能获取,不能设置值

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$location',function($scope,$location){
	// 输出的地址是地址栏中编码后的地址,当地址栏中的地址发生改变时,控制台会得到一个编码后的网址
	//var a = $location.absUrl(); 
	//$location.hash('hello');    // 设置哈希值
	//var a = $location.hash();   // 输出的就是设置的哈希值
	//$location.path('aaa');      // 设置路径,后退可以查看到以前的路径,有利于做路由操作,可以查看历史记录
	//$location.path('aaa').replace(); // 清除之前的路径,后退查看不到以前的路径(一般用不上) 
	//var a = $location.path();
	//$location.search({'age':10}); // 在地址栏中设置信息
	//var a = $location.search();   // 输出的就是年龄信息
	console.log(a)	;
}])


$anchorScroll:锚点跳转

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$anchorScroll','$location',function($scope,$anchorScroll,$location){
	$scope.data = ['1','2','3','4','5','6'];
	$scope.change = function(id){
		$location.hash(id);
		// $anchorScroll();   // 解决在同一的锚点不能跳转的问题,手动跳转
	}
}])
<div ng-controller="A" class="box">
	<ul>
		<li ng-repeat="id in data" ng-click = "change('div'+id)">{{id}}0000000000000</li> // 把id传给change
	</ul>
	<div ng-repeat="id in data" ng-attr-id="div{{id}}">div{{id}}</div>
</div>

$cacheFactory :缓存操作

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$cacheFactory',function($scope,$cacheFactory){
	var cache = $cacheFactory('myCache',{capacity:2});   // 限制缓存的条数,如果数据多余两条,只会留下最后两条数据
	cache.put('name','hello');   // cache.put 添加数据
	cache.put('age','20');
	cache.put('sex','男');
	console.log(cache.info());  // 打印数据包括 id capacity size(代表有几条数据)
	console.log(cache.get('sex'));  // 获取信息
	cache.remove('age');   //移出信息
	console.log(cache.info());
}])

$log的用法

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$log',function($scope,$log){
	$log.log('hello');     // 与console.log用法一样
	$log.error('hello');   // 报错
	$log.warn('hello');    // 警告
	$log.info('hello');    // 信息
}])

$log的供应商

var m1 = angular.module('myApp',[]);
m1.config(['$logProvider',function($logProvider){
	$logProvider.debugEnabled(true);    // 当为true时,$log.debug可以显示提示信息,当为false时,$log.debug不会显示提示信息

}]);
m1.controller('A',['$scope','$log',function($scope,$log){
	$log.debug('hello');
}]);

$interpolate :插值服务

在textarea中输入{{name}}时,输出的是input中的value值 也就是name所对应的属性值,案例:

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$interpolate',function($scope,$interpolate){
	$scope.$watch('area',function(newVal){
		if(newVal){
			var temp = $interpolate(newVal);
			$scope.showText = temp({name:$scope.name})
		}
	})
}])
<div ng-controller="A" class="box">
	<input type="text" ng-model="name">
	<textarea ng-model="area">
	</textarea>
	<p>{{showText}}</p>
</div>


$q :就是promise的实现方式,也就是对异步操作进行功能扩展

$q.defer().resolve:成功

$q.defer().reject:失败

$q.defer().notify:通知

then():监听(成功或者失败)

var m1 = angular.module('myApp',[]);
m1.controller('A',['$scope','$q',function($scope,$q){
	var a = $q.defer()  // 创建了一个延迟对象
	function show(){
		setTimeout(function(){    // 开启一个定时器
			a.reject();       // 让这个延迟失败
		},2000)
		return a.promise;
	}
	show().then(function(){           // 监听看返回的是成功还是失败  
		alert('success');         // 成功弹出 success
	},function(){
		alert('fail');            // 失败弹出 fail
	})	
}])

Provider:供应商(服务的相关初始配置操作,大多数服务都有供应商)

改变差值的初始化配置

var m1 = angular.module('myApp',[]);
m1.config(['$interpolateProvider',function($interpolateProvider){
	$interpolateProvider.startSymbol('@@');  // 改变头部的符号
	$interpolateProvider.endSymbol('@@')     // 改变尾部的符号

}]);
m1.controller('A',['$scope','$interpolate',function($scope,$interpolate){
	$scope.name = "hello";
}]);
<div ng-controller="A">
	<p>@@name@@</p>    // 只有当@@ name @@ ,才会被输出
</div>


$anchorScrollProvider:自动跳转服务的供应商

例如上面的锚点链接跳转的例子,如果对$anchorScrollProvider进行初始化配置,如下代码,就不会完成锚点链接跳转,除非在controller服务中,手动跳转(红色字)

var m1 = angular.module('myApp',[]);
m1.config(['$anchorScrollProvider',function($anchorScrollProvider){
	$anchorScrollProvider.disableAutoScrolling();    // 禁止自动跳转
}]);