A lot of things introduce new scopes. Let's say that in your controllers, you actually want to add tabs : first tab is actual rendering, second tab is the form (so that you have a real-time preview).
You decide to use a directive for that :
<tabs>
<tab name="view">
<pre>{{theText|formatInSomeWay}}</pre>
</tab>
<tab name="edit" focus="true">
<input type="text" ng-model="theText" />
</tab>
</tabs>
Well, know what ? <tabs>
has its own scope, and broke your controller one ! So when you edit, angular will do something like this in js :
$scope.theText = element.val();
which will not traverse the prototype chain to try and set theText
on parents.
EDIT : just to be clear, I'm only using "tabs" as an example. When I say "A lot of things introduce a new scope", I mean it : ng-include, ng-view, ng-switch, ng-controller (of course), etc.
So : this might not be needed as of right now, because you don't yet have child scopes in that view, but you don't know whether you're gonna add child templates or not, which might eventually modify theText
themselves, causing the problem. To future proof your design, always follow the rule, and you'll have no surprise then ;).
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…