我有这个下拉多选指令:
javascript方面:
'use strict';
var app = angular.module('myApp', ['app.directives']);
app.controller('AppCtrl', function($scope){
$scope.roles = [
{"id": 1, "name": "Manager", "assignable": true},
{"id": 2, "name": "Developer", "assignable": true},
{"id": 3, "name": "Reporter", "assignable": true}
];
$scope.member = {roles: []};
$scope.selected_items = [];
});
var app_directives = angular.module('app.directives', []);
app_directives.directive('dropdownMultiselect', function(){
return {
restrict: 'E',
scope:{
model: '=',
options: '=',
pre_selected: '=preSelected'
},
template: "<div class='btn-group' data-ng-class='{open: open}'>"+
"<button class='btn btn-small'>Select</button>"+
"<button class='btn btn-small dropdown-toggle' data-ng-click='open=!open;openDropdown()'><span class='caret'></span></button>"+
"<ul class='dropdown-menu' aria-labelledby='dropdownMenu'>" +
"<li><a data-ng-click='selectAll()'><i class='icon-ok-sign'></i> Check All</a></li>" +
"<li><a data-ng-click='deselectAll();'><i class='icon-remove-sign'></i> Uncheck All</a></li>" +
"<li class='divider'></li>" +
"<li data-ng-repeat='option in options'> <a data-ng-click='setSelectedItem()'>{{option.name}}<span data-ng-class='isChecked(option.id)'></span></a></li>" +
"</ul>" +
"</div>" ,
controller: function($scope){
var count = '1';
$scope.$watch(count, function() {
alert(count)
});
$scope.openDropdown = function(){
$scope.selected_items = [];
for(var i=0; i<$scope.pre_selected.length;i++){ $scope.selected_items.push($scope.pre_selected[i].id);
}};
$scope.selectAll = function () {
$scope.model = _.pluck($scope.options, 'id');
console.log($scope.model);
};
$scope.deselectAll = function() {
$scope.model=[];
console.log($scope.model);
};
$scope.setSelectedItem = function(){
count = count +1;
var id = this.option.id;
if (_.contains($scope.model, id)) {
$scope.model = _.without($scope.model, id);
} else {
$scope.model.push(id);
}
console.log($scope.model);
return false;
};
$scope.isChecked = function (id) {
if (_.contains($scope.model, id)) {
return 'icon-ok pull-right';
}
return false;
};
}
}
});
<script src="http://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.4.4/underscore-min.js"></script>
<link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.0/css/bootstrap-combined.min.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="myApp" ng-controller="AppCtrl">
<dropdown-multiselect pre-selected="member.roles" model="selected_items" options="roles"></dropdown-multiselect>
<pre>selected roles = {{selected_items | json}}</pre>
</div>
Inside指令我有这些行:
$scope.$watch(count, function() {
alert(count)
});
在函数$scope.setSelectedItem
中,我有一行count = count+1
。
当我检查下拉元素中的项目时, count 变量被修改(增加)。
我希望$watch
当计数变量发生变化并弹出警告窗口时会触发。
但是当我从下拉框中选择项目时,警报窗口不会弹出,似乎听众没有被解雇。
知道我错过了什么?为什么$ watch里面的监听器功能没有被解雇?
答案 0 :(得分:1)
您需要在count
上放置$scope
以使用此类观察者。请注意以下更改......
$scope.count = 1;
$scope.setSelectedItem = function() {
$scope.count += 1;
[...]
// -- string argument
$scope.$watch('count', function(newVal, oldVal) {
alert(newVal) // -- or $scope.count
});
JSFiddle Link - 这是一个简单的演示,演示了您的初始方法与此之间的区别。
虽然,您可以将观察者修改为$watch
局部变量,但声明看起来会略有不同。请注意以下内容......
var count = 1;
$scope.setSelectedItem = function() {
count += 1;
[...]
scope.$watch(function () {
return count // -- return local variable
}, function(newVal, oldVal) {
console.log(newVal)
});
JSFiddle Link - $watch
局部变量