AngularJS: wie zu beobachten Registerkarte Auswahl?
Ich bin mit angularjs Registerkarte und Bereich Beispiel Komponenten
angular.module('components', []).
directive('tabs', function() {
return {
restrict: 'E',
transclude: true,
scope: {},
controller: function($scope, $element) {
var panes = $scope.panes = [];
$scope.select = function(pane) {
angular.forEach(panes, function(pane) {
pane.selected = false;
});
pane.selected = true;
}
this.addPane = function(pane) {
if (panes.length == 0) $scope.select(pane);
panes.push(pane);
}
},
template:
'<div class="tabbable">' +
'<ul class="nav nav-tabs">' +
'<li ng-repeat="pane in panes" ng-class="{active:pane.selected}">'+
'<a href="" ng-click="select(pane)">{{pane.title}}</a>' +
'</li>' +
'</ul>' +
'<div class="tab-content" ng-transclude></div>' +
'</div>',
replace: true
};
}).
directive('pane', function() {
return {
require: '^tabs',
restrict: 'E',
transclude: true,
scope: { title: '@' },
link: function(scope, element, attrs, tabsCtrl) {
tabsCtrl.addPane(scope);
},
template:
'<div class="tab-pane" ng-class="{active: selected}" ng-transclude>' +
'</div>',
replace: true
};
})
SomePage.html
<tabs>
<pane title="Datos Generales">
<div ng-include src="'/resources/js/page/running/admin/templates/update-data.html'"></div>
</pane>
<pane title="Localización">
<div ng-include src="'/resources/js/page/running/admin/templates/update-location.html'"></div>
</pane>
<pane title="Datos Contacto">
<div ng-include src="'/resources/js/page/running/admin/templates/update-contacts.html'"></div>
</pane>
<pane title="Variantes">
<div ng-include src="'/resources/js/page/running/admin/templates/update-variants.html'"></div>
</pane>
</tabs>
Im zweiten Bereich gibt es eine GoogleMap. Ich möchte aktualisieren Sie die google-Karte, wenn der zweite Fensterbereich ausgewählt ist.
Ich weiß nicht, wie man ausgewählte Bereich in der Steuerung. Ich habe versucht $scope.panes
aber ist undefined
- Die controller wissen muss? Ein controller, der Sie umgibt, das tabs-element? Ein controller innerhalb des ng-gehören würde update-location.html?
- Ein controller, der Sie umgibt, das tabs-element
- Beachten Sie, dass der v 0.5 (und möglicherweise schon früher), werden auf der Registerkarte Richtlinie kann ein "select" - Attribut, das ist ein '&' Attribut bewertet im übergeordneten Bereich, so ist es nicht mehr notwendig, ändern Sie die ui-bootstrap-code.
- Können Sie bitte schauen Sie in dieses Problem Winkel-Registerkarte Deaktivieren
Du musst angemeldet sein, um einen Kommentar abzugeben.
Hier sind drei Möglichkeiten, wie Sie könnte Ihr problem lösen:
Update: @qopuir gebeten, weitere details zu option 1.
Angenommen, der controller-Methode ist so etwas wie die folgenden:
Auf das tabs-element, wir werden angeben, diese Funktion mit dem Attribut
pane-changed
:Dann die Reiter Richtlinie können die '&' syntax zum aufrufen dieser Methode: