Ich schrieb eine angularjs Direktive, um Ajax Spinner zu zeigen und zu verstecken. Die Sichtbarkeit des Spinner wird durch Schaltflächen zum Ein- und Ausblenden umgeschaltet, deren Funktionalität in den MainController geschrieben wird. Es gibt eine Variable innerhalb des Controllers, die basierend auf dem Knopfklick auf Wahr und Falsch gesetzt wird. Diese Variable wird mithilfe von isolate scope an die Direktive übergeben. Wenn ich versuche, einen Spinner umzuschalten, sind auch alle anderen Spinner sichtbar. Wie kann ich meinen Code ändern, um nur den bestimmten Spinner umzuschalten?toggling eine Direktive Effekte andere dircetive in ngrepeat
https://plnkr.co/edit/AFmBVbHaBPk66T7UjPC5?p=preview
// Code goes here
angular.module('app',[])
.controller('MainController',[MainController])
.directive('loadingDirective',[loadingDirective]);
function MainController(){
var mc = this;
mc.showMe = showMe;
mc.hideMe = hideMe;
mc.loading = false;
function showMe(){
mc.loading = true;
}
function hideMe(){
mc.loading = false;
}
}
function loadingDirective() {
return {
restrict: 'E',
replace:true,
scope:{
loading:"=loading"
},
template: '<span class="spinner">Loading…</span>',
link: function (scope, element, attr) {
scope.$watch('loading', function (val) {
if (val)
$(element).show();
else
$(element).hide();
});
}
};
}
/* Styles go here */
.spinner {
position: relative;
/* [1] */
display: inline-block;
width: 1em;
/* [2] */
height: 1em;
/* [2] */
font-size: 32px;
/* [3] */
border-bottom: 1px solid;
/* [4] */
vertical-align: middle;
overflow: hidden;
/* [5] */
text-indent: 100%;
/* [5] */
-webkit-animation: 0.5s spinner linear infinite;
animation: 0.5s spinner linear infinite;
/**
* 1. Make the spinner a circle.
*/
/**
* The (optically) non-spinning part of the spinner.
*
* 1. Border around entire element fills in the rest of the ring.
* 2. Paler than the part that appears to spin.
*/
}
.spinner, .spinner:after {
border-radius: 100%;
/* [1] */
}
.spinner:after {
content: "";
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
border: 1px solid;
/* [1] */
opacity: 0.5;
/* [2] */
}
/**
* Size variants (built by adjusting `font-size`).
*/
.spinner--small {
font-size: 16px;
}
.spinner--large {
font-size: 64px;
}
/**
* Color overrides.
*/
.spinner--light {
color: #fff;
}
.spinner--dark {
color: #333;
}
@-webkit-keyframes spinner {
to {
-webkit-transform: rotate(360deg);
}
}
@keyframes spinner {
to {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}
<!DOCTYPE html>
<html ng-app="app">
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
</head>
<body>
<h1>Hello Plunker!</h1>
<div ng-controller="MainController as mc">
<div ng-repeat="i in [1,2,3,4,5]">
<loading-directive loading="mc.loading"></loading-directive>
<button ng-click="mc.showMe()">show</button>
<button ng-click="mc.hideMe()">hide</button>
</div>
</div>
</body>
</html>
[Icycool] (http://stackoverflow.com/users/5039495/icycool) Antwort ist besser geeignet für mein Problem da ich das Umschalten des Spinners vor und nach einem Ajax-Aufruf steuern muss, um das Laden zu signalisieren. Die von [Nivedit] (http://stackoverflow.com/users/5002305/nivedit) zur Verfügung gestellte Lösung ist jedoch sehr allgemein und kann in vielen Situationen verwendet werden. Vielen Dank für die Hilfe Jungs. –