web-dev-qa-db-fra.com

Modifier bootstrap largeur de la barre de progression à partir d'angularjs

Je suis nouveau dans Angularjs et j'essaie de mettre à jour la largeur d'une barre de progression lorsqu'une valeur dans mon contrôleur change.

J'ai quelque chose comme:

<span id="percentage">$ {{getTotal()}} ({{getPercentage()}}%)</span>
<div class="progress-bar progress-bar-warning" 
  role="progressbar" aria-valuenow="10" aria-valuemin="0" 
  aria-valuemax="100" style="width: 10%">
    <span class="sr-only">10% Complete (warning)</span>
</div>

Et j'ai dans mon contrôleur quelque chose comme:

$scope.total = 254.78;
$scope.threshold = 15000;

$scope.getPercentage = function () {
    return (($scope.total * 100) / $scope.threshold).toFixed(2);
}
$scope.getTotal = function () {
    return $scope.total;
}

Comment mettre à jour la valeur de largeur de la barre de progression?

Merci, Alberto.

18
axy108

la directive de style ng ferait l'affaire.

<span id="percentage">$ {{getTotal()}} ({{getPercentage()}}%)</span>
<div class="progress-bar progress-bar-warning" 
  role="progressbar" aria-valuenow="{{getPercentage()}}" aria-valuemin="0" 
  aria-valuemax="100" ng-style="{width : ( getPercentage() + '%' ) }">
    <span class="sr-only">{{getPercentage()}}% Complete (warning)</span>
</div>
46
Dog

J'utiliserais une directive pour cela, qui est responsable du calcul de la largeur par elle-même.

module.directive("progressbar", function () {
    return {
        restrict: "A",
        scope: {
            total: "=",
            current: "="
        },
        link: function (scope, element) {

            scope.$watch("current", function (value) {
                element.css("width", scope.current / scope.total * 100 + "%");
            });
            scope.$watch("total", function (value) {
                element.css("width", scope.current / scope.total * 100 + "%");
            })
        }
    };
});

http://jsfiddle.net/rGWUR/10/

3
kfis

Je pense que la meilleure solution consiste à utiliser la barre de progression Angle -UI à la place pour essayer de réinventer la roue https://angular-ui.github.io/bootstrap/#/progressbar .

<uib-progressbar value="50"></uib-progressbar>
2
FelipeCaparelli

Eh bien, vous devriez faire quelque chose comme ça:

<div class="progress-bar progress-bar-warning" 
  role="progressbar" aria-valuenow="{{getPercentage()}}" aria-valuemin="0" 
  aria-valuemax="100" style="width: {{getPercentage()}} %">
    <span class="sr-only">{{getPercentage()}}% Complete (warning)</span>
</div>
2
Ashish Kumar

Vous pouvez écrire un ng-style Personnalisé:

 <div class="progress-bar progress-bar-warning"
    role="progressbar" 
    aria-valuenow="10"
    aria-valuemin="0"
    aria-valuemax="100" 
    ng-style="percentageStyle">
        <span class="sr-only">10% Complete (warning)</span>
 </div>

et dans le contrôleur:

 $scope.percentageStyle = {
   width : $scope.getPercentage() + '%'     
 };

Démo Fiddle

1
Maxim Shoustin