I keep finding new stuff inside Angular 1.3. One of the things I found is the bindToController attribute. I’m an advocate of using the controllerAs syntax to get rid of the $scope variable. The only problem before is that in a directive you still had to use $scope…until now.
Let’s first have a look at what the AngularJS documentation has to say about the bindToController attribute:
When an isolate scope is used for a component (see above), and
controllerAs
is used,bindToController: true
will allow a component to have its properties bound to the controller, rather than to scope. When the controller is instantiated, the initial values of the isolate scope bindings are already available
Before scope variables were not included in the controller scope when controllerAs was used. This means that the directive's scope variables were not bound to the object created by controllerAs. The bindToController attribute fixes this.
Enough talk, show me the code:
(function(app) { | |
'use strict'; | |
app.directive('searchBox', searchBox) | |
function searchBox() { | |
return { | |
restrict: 'E', | |
scope: { | |
searchField: '@', | |
searchValue: '=searchTerm' | |
}, | |
controller: MusicPlayerCtrl, | |
controllerAs: 'MusicPlayerCtrl', | |
bindToController: true, | |
template: '<div class="input-control text"><input type="text"></input><button class="btn-search"></button></div>' | |
link: function(scope, element, attrs, ctrl) { | |
element.bind('click', function() { | |
console.log(ctrl.search()); | |
}) | |
} | |
} | |
} | |
function SearchCtrl() { | |
} | |
SearchCtrl.prototype.search = function() { | |
return 'Searching for"' + this.searchTerm + ' on field ' + this.searchField + '"...'; | |
} | |
})(angular.module('app', [])) |