プログレスバーに対応するAngularJSコンポーネントを作成しようとしています。AngularJSコンポーネントで新しい変数を定義する方法
var myApp = angular.module('myApp',[]);
myApp.controller('TestController', function($scope) {
$scope.total = 20;
$scope.count = 15;
$scope.changeTotal = function(value){$scope.total += value};
$scope.changeCount = function(value){$scope.count += value};
});
myApp.component('progressBar', {
bindings: {
percentage: '=',
},
controller: function() {
this.width = this.percentage * 100;
},
template: '<div class="progressBar">\
<div class="inner" style="width: [[$ctrl.width]]%"></div>\
</div>',
});
そして、次のHTMLコード:
<div ng-app="myApp">
<div ng-controller="TestController">
Total: {{total}}, <button ng-click="changeTotal(-1)">-</button><button ng-click="changeTotal(+1)">+</button><br/>
Count: {{count}}, <button ng-click="changeCount(-1)">-</button><button ng-click="changeCount(+1)">+</button><br/>
Percentage: {{count/total}}%<br/>
<br/>
<progress-bar percentage="{{count/total}}"></progress-bar>
</div>
</div>
でwidth
属性の定義にもかかわらず、ここでJSFiddleはここhttp://jsfiddle.net/Lvc0u55v/6725/
は私のアプリケーションとコンポーネントの定義で、この質問のために作成されますAngularJSは、定義されたテンプレートでそれを見つけることができません。
私はちょうどAngularJSを学び始めて以来、このコードを効率的にデバッグするのが難しいです。
それを動的に正しく処理する共通のサービスです。 – GMaiolo
@Goliadkin親愛なる人、あなたはフィドルをチェックしましたか?これは '='が双方向ビンディングのために使われる方法です。 –
@PankajParkarありがとう!プログレスバーは移動しないので、あなたの変更にもかかわらず、動作していません:(私は幅を正しく設定するために編集しました( '* 100'はありませんでした):http://jsfiddle.net/p8xqyhng/2/ 2番目の質問は、var 'self = this;'が? –