در این مقاله به بررسی سرویس ها در آنگولارجی اس می پردازیم.
شما میتوانید در آنگولار، سرویس های خود را ایجاد و یا از سرویس های موجود استفاده کنید.
سرویس چیست؟
در آنگولارجی است ، سرویس یک عملگر یا شیئ است که در محدوده نرم افزار شما قابل اجرا است.
آنگولار جی اس حدود 30 سرویس built-in services دارد . یکی از آنها سرویس $location است.
مثال:
استفاده از سرویس $location در یک کنترلر:
var app = angular.module('myApp', []);
app.controller('customersCtrl', function($scope, $location) {
$scope.myUrl = $location.absUrl();
});
مشاهده نتیجه
نکته : سرویس $location همراه با آروگمان متوقف میگردد. بنابراین باید سرویس را در ارتباط با آروگمان نوشت
چرا از سرویس ها استفاده کنیم؟
برای خیلی از سرویس ها مانند سرویس $location مانند استفاده از این امکان توسط DOM است درست مانند استفاده از شیئ window.location ولی اینکار ممکن است برای کار در آنگولار جی است محدودیت ایجاد کند. بنابراین این دستور را در همان آنگولار ایجاد می کنیم.
آنگولار جی است پیشنهاد میدهد که از سرویس $location بجای شیئ window.location استفاده کنیم.
سرویس $http :
سرویس $http یکی از پرکاربردترین سرویس ها در آنگولارجی اس است . سرویس یک تقاضا به سرور ارسال می کند. و شما امکان عکس العمل به پاسخ سرور را خواهید داشت .
مثال:
استفاده از سرویس $http برای ارسال درخواست به سرور :
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope, $http) {
$http.get("welcome.htm").then(function (response) {
$scope.myWelcome = response.data;
});
});
مشاهده نتیجه
در آموزش بعدی درباره این سرویس بیشتر توضیح میدهیم.
سرویس $timeout
این سرویس نسخه آنگولار از عملگر window.setTimeout است.
مثال
نمایش یک پیام بعد از دو ثانیه
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope, $timeout) {
$scope.myHeader = "Hello World!";
$timeout(function () {
$scope.myHeader = "How are you today?";
}, 2000);
});
مشاهده نتیجه
سرویس $interval
سرویس $interval یک نسخه آنگولارجی اس از عملگر window.setInterval میباشد.
مثال
نمایش زمان در هر ثانیه:
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope, $interval) {
$scope.theTime = new Date().toLocaleTimeString();
$interval(function () {
$scope.theTime = new Date().toLocaleTimeString();
}, 1000);
});
مشاهده نتیجه
ساخت سرویس سفارشی خود
برای ساخت سرویس خود و اتصال آن به یک ماژول
یک سرویس به نام hexafy ایجاد کنید:
app.service('hexafy', function() {
this.myFunc = function (x) {
return x.toString(16);
}
});
برای استفاده از سرویسی که ایجاد کرده اید، بعنوان یک عامل مرتبط به کنترلرمعرفی کنید:
مثال
استفاده از سرویس hexafy سفارشی خود برای تبدیل عدد به کد هگزا دسیمال:
app.controller('myCtrl', function($scope, hexafy) {
$scope.hex = hexafy.myFunc(255);
});
مشاهده نتیجه
استفاده از سرویس سفارشی در داخل یک فیلتر
بعد از ایجاد یک سرویس و اتصال آن به نرم افزار شما میتوانید آنرا درون یک کنترلر،دستورالعمل، فیلتر و یا حتی سرویس دیگری بکار بگیرید.
برای استفاده از سرویس در داخل یک فیلتر آن را به عنوان عضوی وابسته به فیلتر اضافه کنید:
The service hexafy used in the filter myFormat:
app.filter('myFormat',['hexafy', function(hexafy) {
return function(x) {
return hexafy.myFunc(x);
};
}]);
مشاهده نتیجه
شما میتوانید از فیلتر هنگام نمایش یک داده از یک شیئ یا یک آرایه استفاده کنید.
ایجاد یک سرویس به نام hexafy :
<ul>
<li ng-repeat="x in counts">{{x | myFormat}}</li>
</ul>
مشاهده نتیجه
براي بهره مندي از مشاوره تخصصي در زمینه طراحی سایت در کرج با شرکت سارگون تماس بگيريد