5 回答

TA貢獻1818條經驗 獲得超3個贊
在angularjs的config中使用service的方法:
它是一個可注入的構造器,在AngularJS中它是單例的,用它在Controller中通信或者共享數據都很合適
var app = angular.module('app' ,[]);
app.config(function ($provide) {
$provide.service('movie', function () {
this.title = 'The Matrix';
});
});
app.controller('ctrl', function (movie) {
expect(movie.title).toEqual('The Matrix');
});
語法糖:
app.service('movie', function () {
this.title = 'The Matrix';
});
在service里面可以不用返回東西,因為AngularJS會調用new關鍵字來創建對象。但是返回一個自定義對象好像也不會出錯。

TA貢獻1875條經驗 獲得超3個贊
1.第一種是通過調用Context.startService()啟動,調用Context.stopService()結束,startService()可以傳遞參數給Service
2.第二種方式是通過調用Context.bindService()啟動,調用Context.unbindservice()結束,還可以通過ServiceConnection訪問Service。
在Service每一次的開啟關閉過程中,只有onStart可被多次調用(通過多次startService調用),其他onCreate,onBind,onUnbind,onDestory在一個生命周期中只能被調用一次。

TA貢獻1850條經驗 獲得超11個贊
可以通過在activity中 設置事件 。當事件出發時 利用intent
Intent intent=new Intent(MainActivity.this, ServiceDemo.class);
switch (v.getId())
{ case R.id.startBtn:
startService(intent); 啟動
break;
case R.id.stopBtn:
stopService(intent); 停用
break;
default:
break;

TA貢獻1943條經驗 獲得超7個贊
Service的典型示例
在AngularJS中,Service都是單例的實體,通常會將Service作為向后臺交互的數據提供者,所有的需要數據的組件只需要依賴于這個Service即可。
var app = angular.module('MyApp', []);
app.factory('SearchSettingService',
['$http', '$q', function($http, $q) {
return {
setting: function() {
var deferred = $q.defer();
$http.get('/settings.json').success(function(result) {
deferred.resolve(result);
}).error(function(result) {
deferred.reject("network error");
});
return deferred.promise;
}
};
}]);
$httpBackend
測試的時候,我們不需要真實的發送HTTP請求來獲取數據。如果可以只測試Service的邏輯,當發送請求時,我們將這個請求攔截下來,然后返回一個預定義好的數據即可:
it('should have settings from http request', function() {
var result;
var expected = {
"period": "day",
"date": "Sat Dec 21 12:56:53 EST 2013",
};
httpBackend.expectGET('/settings.json').respond(expected);
var promise = settingService.setting();
promise.then(function(data) {
result = data;
});
- 5 回答
- 0 關注
- 1143 瀏覽
添加回答
舉報