如何更新指令中的范围?
<div ng-controller="MyCtrl">
<p t></p>
</div>
我的指令:
var myModule = angular.module('myModule', [])
.directive('t', function () {
return {
template: '{{text}}',
link: function (scope, element, attrs) {
scope.text = '1';
element.click(function() {
scope.text = '2';
});
}
};
})
.controller('MyCtrl', ['$scope', function ($scope) {
}]);
单击后指令不更新。
最佳答案
使用 $apply
方法:
element.click(function() {
scope.$apply(function(){
scope.text = '2';
});
});
说明:How does data binding work in AngularJS?
关于angularjs - Angular.js 如何从指令更新范围?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19154539/