У меня есть полностью работающее приложение Ionic, в которое я добавил угловые переключатели для управления определенными div в представлении.
Проблема возникает на панели ion-footer-bar. Всегда по умолчанию используется facebook (индекс 0) и просто полностью игнорируется instagram ng-switch-when
. В разработчике Chrome я ясно вижу, как работает ng-switch, но ошибочное поведение сохраняется, что бы я ни делал.
Я пробовал всевозможные изменения безрезультатно, я начинаю думать, что это связано с тем, как Ionic создает его ion-content и ion-footer-bar strong > элементы (?)
HTML
<ion-content>
<select ng-model="selectedNetwork" ng-change="setSelected(selectedNetwork.id)" data-ng-options="availableNetwork as availableNetwork.label for availableNetwork in availableNetworksForSelect track by availableNetwork.id">
</select>
//*******Please note that These two divs work perfectly*********
<div ng-switch = "selectedNetwork.id" class="">
<div ng-switch-when = "facebook" class="" >
<span>I am Facebook</span>
</div>
<div ng-switch-when = "instagram" class="">
<span>I am instagram</span>
</div>
</div>
</ion-content>
<ion-footer-bar ng-switch = "selectedNetwork.id">
<div ng-switch-when = "facebook" class="" >
<span>I am Facebook</span>
</div>
<div ng-switch-when = "instagram" class="">
<span>I am instagram</span>
</div>
</ion-footer-bar>
Это контроллер
$scope.availableNetworksForSelect = [{
id: 'facebook',
label: 'This is Facebook'
}, {
id: 'instagram',
label: 'This is instagram'
}];
$scope.selectedNetwork = $scope.availableNetworksForSelect[0];
РЕДАКТИРОВАТЬ: по запросу, вот setSelected();
$scope.setSelected = function (network) {
console.log('setSelected', network)
$scope.selectedTab = network;
$scope.translationData = {
network: network.charAt(0).toUpperCase() + network.substring(1)
};
var currentTabNetworkTerms;
if (!_.isUndefined($scope.baba.networks)) {
currentTabNetworkTerms = _.find($scope.baba.networks, {code: network}).actions;
$scope.currentTabNetworkActions = _.sortBy(currentTabNetworkTerms, function (term) {
if (term.name == "post") {
return 0;
}
return 1;
});
}
}
ion-content
, поэтомуion-footer-bar
выходит за рамки ее области - person devqon   schedule 07.03.2017