0
我在寫一組可以互相聯繫的指令時遇到了這個問題。
這裏是CodePen網址:http://codepen.io/jennieji/pen/mDGuw
這裏是JS代碼:
angular.module('app', [])
.directive('testDirective', function() {
return {
controller: function($scope){
$scope.now = 0;
this.update = function() {
$scope.now++;
};
},
link: function(scope) {
scope.$watch(function(){
return scope.now;
}, function(newVal, oldVal) {
element.append('<p>[LOG] $watch now:' + newVal + '</p>');
}, true);
scope.$watch('now', function(newVal, oldVal) {
element.append('<p>[LOG] $watch now:' + newVal + '</p>');
});
}
};
})
.directive('testUpdate', function() {
return {
require: '^testDirective',
link: function(scope, element, attr, ctrl) {
element.on('click', function(){
ctrl.update();
element.after('<p>[LOG] click now:' + scope.now + '</p>');
});
}
}
});
這裏是HTML:
<div ng-app="app">
<div test-directive>
<p>{{ now }}</p>
<button test-update>Update now</button>
</div>
<div>
雙向綁定的作品!但$手錶仍然不工作,爲什麼? – 2014-09-10 09:32:23
不確定控制器作用域是否與鏈接作用域相同。你可能想先確認一下。 – 2014-09-10 09:35:55
是的,你是對的。謝謝。 – 2014-09-10 09:44:18