我有一个范围变量'$ scope.searchType',它默认等于'createdAt'。在我的HTML我有改变的范围变量值的选项:
<ul class="dropdown-menu" role="menu">
<li><a ng-click="searchType = 'Anything'">Anything</a></li>
<li><a ng-click="searchType = 'Payment'">Payment</a></li>
<li><a ng-click="searchType = 'Total'">Total</a></li>
<li><a ng-click="searchType = 'Tax'">Tax</a></li>
<li><a ng-click="searchType = 'Payment Method'">Payment Method</a></li>
</ul>
在我的控制,我有以下监听变化:
$scope.$watch('searchType', function(newValue) {
if(newValue == 'Payment') {
$scope.searchTypeFilter = 'id';
$scope.searchFiltered = true;
} else if(newValue == 'Total') {
$scope.searchTypeFilter = 'total';
$scope.searchFiltered = true;
} else if(newValue == 'Tax') {
$scope.searchTypeFilter = 'tax';
$scope.searchFiltered = true;
} else if(newValue == 'Payment Method') {
$scope.searchTypeFilter = 'paymentType';
$scope.searchFiltered = true;
} else {
$scope.searchTypeFilter = '';
$scope.searchFiltered = false;
$scope.search = '';
}
}, true);
出于某种原因,$范围$手表永远不会调用。我无法弄清楚它以前是如何不起作用的。这是'$ scope.searchType'声明:
$scope.sortType = 'createdAt';
贵'下拉-menu' HTML被包裹在你的推杆了'$ watch'控制器? –
你确定手表和下拉菜单在同一范围内吗? – ajmajmajma
是的,我相信他们自$ scope。$ watch在页面加载时输入一次。但之后它永远不会再运行。 – Niraj