در این مقاله قصد دارم تکنیکی ساده ولی در عین حال موثر را معرفی کنم که در نوشتن کنترلرها بسیار کارآمد است. همانطور که میدانید به طور معمول برای تعریف متدها و پراپرتیهای درون کنترلر و انتقال آن به View، از دو روش انتساب به scope$ و controller as استفاده میشود.
حال ببینیم که متد angular.extend کد فوق را چگونه ساده سازی میکند. همانطور که مشاهده میکنید توسط extend، تمامی متدها و پراپرتیها به صورت یکجا به scope انتساب داده شده است.
استفاده از angular.extend باعث میشود که تمامی assignmentها به صورتتر و تمیز درون scope یا this قرار بگیرند. حال اینکه نیازی نیست تا شما تمامی این assingmentها را به صورت یکجا و توسط یک بار صدا زدن extend انجام دهید. شما میتوانید در نقاط مختلف کنترلر این متد را با مقادیر انتسابی متفاوتی فراخوانی کنید. تکه کد زیر نمونهی تغییر یافته به صورت دو بار فراخوانی extend است:
حال قصد داریم تا کمی ساختار کد پیشین را مستحکمتر کنیم. در بسیاری از مواقع اطلاعات دریافتی از view به این صورت است که در ابتدا نیاز به تایید صلاحیت دارند. در تکه کد زیر قصد داریم تا به متغیرهای thingObe و thingTwo دو متد getter و setter را اضافه نماییم و پراپرتیها را از حالت public خارج کنیم. در کد زیر ما، دو متد getter و setter برای هر کدام از متغیرها که به حالت private تعریف شدهاند، اضافه کرده ایم:
و در آخر اینکه با استفاده از این متد میتوان ارث بری در سرویسهای Angular را پیاده سازی کرد که جزئیات آن را میتوانید از اینجا دریافت کنید.
در AngularJs متدی به صورت built-in وجود دارد که قادر است یک شیء را درون شیء دیگر کپی کند. این متد در بسیاری از مواقع بسیار کارآمد است که به بررسی آن خواهیم پرداخت. جزئیات بیشتر و دقیقتر در مورد angular.extend را میتوانید در اسناد سایت رسمی AngularJs مشاهده کنید.
به تکه کد زیر توجه کنید. این کد نمونهای از استفادهی از scope$ است. مشاهده میکنید که متغییرهای thingOne و thingTwo چگونه درون scope$ قرار میگیرد.
app.controller(‘ThingController’, [ ‘$scope’, function($scope) { $scope.thingOne = ‘one’; $scope.thingTwo = ‘two’; $scope.getThings = function() { return $scope.thingOne + ‘ ‘ + $scope.thingTwo; }; }]);
app.controller(‘ThingController’, [ ‘$scope’, function($scope) { angular.extend($scope, { thingOne: ‘one’, thingTwo: ‘two’, getThings: function() { return $scope.thingOne + ‘ ‘ + $scope.thingTwo; } }); }]);
app.controller(‘ThingController’, [ ‘$scope’, function($scope) { // models angular.extend($scope, { thingOne: ‘one’, thingTwo: ‘two’ }); // methods angular.extend($scope, { // in HTML template, something like {{ getThings() }} getThings: function() { return $scope.thingOne + ‘ ‘ + $scope.thingTwo; } }); }]);
app.controller(‘ThingController’, [ ‘$scope’, function($scope) { // private var _thingOne = ‘one’, _thingTwo = ‘two’; // models angular.extend($scope, { get thingOne() { return _thingOne; }, set thingOne(value) { if (value !== ‘one’ && value !== ‘two’) { throw new Error(‘Invalid value (‘+value+‘) for thingOne’); }, get thingTwo() { return _thingTwo; }, set thingTwo(value) { if (value !== ‘two’ && value !== ‘three’) { throw new Error(‘Invalid value (‘+value+‘) for thingTwo’); } }); // methods angular.extend($scope, { // in HTML template, something like {{ things }} get things() { return _thingOne + ‘ ‘ + _thingTwo; } }); }]);