मैंने गूगल मैप्स के साथ एकीकृत फैक्ट्री के साथ काम किया है जो स्वत: पूर्ण और किए गए वादे हैं, मुझे उम्मीद है कि आप सेवा करेंगे।
http://jsfiddle.net/the_pianist2/vL9nkfe3/1/
आपको केवल कारखाने से पहले $ http incuida के साथ इस अनुरोध के द्वारा स्वतः पूर्ण सेवा को बदलने की आवश्यकता है।
app.factory('Autocomplete', function($q, $http) {
और $ http अनुरोध के साथ
var deferred = $q.defer();
$http.get('urlExample').
success(function(data, status, headers, config) {
deferred.resolve(data);
}).
error(function(data, status, headers, config) {
deferred.reject(status);
});
return deferred.promise;
<div ng-app="myApp">
<div ng-controller="myController">
<input type="text" ng-model="search"></input>
<div class="bs-example">
<table class="table" >
<thead>
<tr>
<th>#</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="direction in directions">
<td>{{$index}}</td>
<td>{{direction.description}}</td>
</tr>
</tbody>
</table>
</div>
'use strict';
var app = angular.module('myApp', []);
app.factory('Autocomplete', function($q) {
var get = function(search) {
var deferred = $q.defer();
var autocompleteService = new google.maps.places.AutocompleteService();
autocompleteService.getPlacePredictions({
input: search,
types: ['geocode'],
componentRestrictions: {
country: 'ES'
}
}, function(predictions, status) {
if (status == google.maps.places.PlacesServiceStatus.OK) {
deferred.resolve(predictions);
} else {
deferred.reject(status);
}
});
return deferred.promise;
};
return {
get: get
};
});
app.controller('myController', function($scope, Autocomplete) {
$scope.$watch('search', function(newValue, oldValue) {
var promesa = Autocomplete.get(newValue);
promesa.then(function(value) {
$scope.directions = value;
}, function(reason) {
$scope.error = reason;
});
});
});
सवाल खुद पर बनाया जाना है:
deferred.resolve(varResult);
जब आपने अच्छा किया है और अनुरोध किया है:
deferred.reject(error);
जब कोई त्रुटि होती है, और तब:
return deferred.promise;