When Do Isolated Scope Properties Actually Get Added To The Scope?
Solution 1:
I found that this works inside the directive definition:
scope: {
prop1: '@'
},
link: function(scope, element, attrs) {
...
attrs.$observe('prop1', function(val) {
scope.prop1 = val || 'default'
});
...
}
to make
<div my-directive></div>
behave like
<divmy-directiveprop1="default"></div>
Solution 2:
Here's my understanding: In general in a directive, you can not assume that any variable in a scope is defined or has a stable value. You need to $watch anything that's of interest to you.
Think of ng-repeat - the thing that you're repeating on might not exist at link time, it might change often, etc. - it's up to the directive to handle those scenarios.
Now I know that doesn't answer your question - you're creating an isolated scope which is explicitly setting a scope value, so intuitively what you're doing is different than the ng-repeat example. But it looks like Angular treats them the same and this is probably a good thing.
Depending on what you need to use the attribute for I think you can solve your problem in two ways:
- If it's an evaluated value and it might change, wrap it in a watch so you can react.
- If it's a static value you can use attrs.prop1 and pull it down at the beginning of your link fn.
Both of these options I've added to the fiddle here.
Post a Comment for "When Do Isolated Scope Properties Actually Get Added To The Scope?"