[英]Angularjs Show and Hide Button within ng-repeat
我有一個列表,使用ng-repeat
填充屏幕。 每行都有一個按鈕供用戶單擊以選擇行。 通常你會使用單選按鈕,但用戶想要一個按鈕切換。
我真正想要的是顯示第一個按鈕(在第一次顯示列表時隱藏第二個按鈕),在用戶點擊第一個按鈕以選擇特定行之后,我想隱藏第一個按鈕並顯示第二個按鈕。 2按鈕具有不同的ID,文本,樣式。 所以對用戶來說,就像選擇后更改按鈕的外觀一樣。
我嘗試在showfarebut1
中的函數populateFareOption(row.col3.value, row.col4.value)
中設置showfarebut1
/ showfarebut2
范圍變量,但是在單擊按鈕1之后所有行都有第二個按鈕。
任何想法或代碼片段..將不勝感激。
<tr ng-repeat="row in rowList">
<td> {{row.col1.value}}</td>
<td>
<span class="price">PRICE:
<strong class="amount">{{row.col2.value}}</strong>
</span>
<button id="btnXX1" ng-show="showfarebut1" type="button" class="btn pull-right" ng-click="populateFareOption(row.col3.value,row.col4.value)">
<span class="text pull-left" name="fareOption" ng-model="travelCardForm.colOption" value="{{row.col3.value}}">Select</span>
<i class="icon-placeholder"></i>
</button>
<button id="btnXX2" ng-show="showfarebut2" type="button" class="btn pull-right">
<span class="text pull-left">Selected</span>
<i class="selected-icon pull-right"></i>
</button>
</td>
</tr>
$scope.showfarebut1=true;
$scope.showfarebut2=false;
$scope.populateFareOption = function(x,y){
cardForm.fareOption.value=x;
cardForm.productCode.value=y;
$scope.showfarebut1=false;
$scope.showfarebut2=true;
}
在您的示例中,您在所有行中共享showfarebut1
和showfarebut2
,這會導致單擊一個按鈕影響所有行。 你應該使用綁定到當前行的東西: row.showfarebut1
和row.showfarebut2
。
但是,有一種更有效的方法來制作切換按鈕。 您可以重復使用相同的按鈕,並根據記錄的狀態設置類和文本。 這是一個簡單的例子:
HTML
<ul class="list-group" ng-controller="ctrl">
<li class="list-group-item" ng-repeat="row in rowList">
<span>{{row.col1.value}}</span>
<span>{{row.col2.value}}</span>
<button type="button" ng-click="row.selected=!row.selected" class="pull-right btn btn-xs">
<span ng-class="{'glyphicon':true, 'glyphicon-ok':row.selected, 'glyphicon-plus':!row.selected}"></span>
{{row.selected?'Selected':''}}
</button>
</li>
</ul>
您可以使用ng-class
指令切換類和條件,如{{row.selected?'Selected':''}}
來切換按鈕的文本。
JavaScript的
angular.module('app', []).
controller('ctrl', function($scope) {
$scope.rowList = [{
col1: { value: 'r1c1'},
col2: {value: 'r1c2'}
}, {
col1: {value: 'r2c1'},
col2: {value: 'r2c2'}
}, {
col1: {value: 'r3c1'},
col2: {value: 'r3c2'}
}];
});
您甚至不需要一些特殊功能來選擇項目,您可以直接在ng-click
執行簡單的操作
截圖
Plunker: http ://plnkr.co/edit/ZFRIWOe2HxMq8K11FBk4?p =preview
編輯(改編版):
HTML
<table ng-controller="ctrl" class="table">
<tr ng-repeat="row in rowList">
<td>{{row.col1.value}}</td>
<td>
<span class="price">PRICE:
<strong class="amount">{{row.col2.value}}</strong>
</span>
<button id="btn{{$index}}" type="button" class="btn pull-right" ng-click="select(row)">
<span class="text pull-left" name="fareOption" value="{{row.col3.value}}">{{row.selected?'Selected':'Select'}}</span>
<i ng-class="{'icon-placeholder':!row.selected, 'selected-icon':row.selected, 'pull-right':row.selected}"></i>
</button>
</td>
</tr>
</table>
JavaScript的
angular.module('app', []).
controller('ctrl', function($scope) {
$scope.rowList = [{
col1: {value: 'Orange'},
col2: {value: '10'},
col3: {value: 'x1'},
col4: {value: 'y1'}
}, {
col1: {value: 'Apple'},
col2: {value: '20'},
col3: {value: 'x2'},
col4: {value: 'y2'}
}, {
col1: {value: 'Banana'},
col2: {value: '15'},
col3: {value: 'x3'},
col4: {value: 'y3'}
}];
$scope.select = function(row) {
row.selected=!row.selected;
// Do something with row.col3.value and row.col4.value
}
});
Plunker: http ://plnkr.co/edit/DdO1zBXxkyXWSLA6Gv2x?p=preview
附加showfarebut2
到對象rowList
:
$scope.populateFareOption = function(row){
cardForm.fareOption.value = row.col3.value;
cardForm.productCode.value = row.col4.value;
row.showFareBut2 = true;
}
你的HTML:
<button id="btnXX2" ng-show="row.showfarebut2" type="button" class="btn pull-right">
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.