-2
複選框,這是在表頭不工作,以及如何使用複選框複選框無法正常工作
(function() {
'use strict';
angular
.module('banksApp')
.controller('HdfcController', HdfcController);
HdfcController.$inject = ['$scope', '$state', 'Hdfc', 'ParseLinks', 'AlertService'];
function HdfcController ($scope, $state, Hdfc, ParseLinks, AlertService) {
var vm = this;
vm.hdfcs = [];
vm.loadPage = loadPage;
vm.page = 0;
vm.links = {
last: 0
};
vm.predicate = 'id';
vm.reset = reset;
vm.reverse = true;
vm.checkAll = [];
var map = {};
vm.checkboxes = [];
vm.selectedItems = [];
vm.selectAll = selectAll;
vm.select = select;
loadAll();
function loadAll() {
Hdfc.query({
page: vm.page,
size: 20,
sort: sort()
}, onSuccess, onError);
function sort() {
var result = [vm.predicate + ',' + (vm.reverse ? 'asc' : 'desc')];
if (vm.predicate !== 'id') {
result.push('id');
}
return result;
}
function onSuccess(data, headers) {
vm.links = ParseLinks.parse(headers('link'));
vm.totalItems = headers('X-Total-Count');
for (var i = 0; i < data.length; i++) {
vm.hdfcs.push(data[i]);
}
}
function onError(error) {
AlertService.error(error.data.message);
}
}
function reset() {
vm.page = 0;
vm.hdfcs = [];
loadAll();
}
function loadPage(page) {
vm.page = page;
loadAll();
}
function selectAll() {
var value = vm.checkAll[vm.page];
angular.forEach(vm.hdfcs, function(item) {
if (angular.isDefined(item.id)) {
if(vm.checkboxes[item.id] != value) {
vm.checkboxes[item.id] = value;
vm.select(item);
}
}
});
};
function select (item) {
var value = vm.checkboxes[item.id];
if(value) {
vm.selectedItems.push(item);
if(map[vm.page] == null) map[vm.page] = 1;
else map[vm.page] = map[vm.page] + 1;
if(map[vm.page] == vm.hdfcs.length) {
vm.checkAll[vm.page] = true;
}
} else {
vm.selectedItems.splice(item, 1);
if(map[vm.page] == null) map[vm.page] = 0;
else map[vm.page] = map[vm.page] - 1;
if(map[vm.page] < vm.hdfcs.length) {
vm.checkAll[vm.page] = false;
}
}
};
}
})();
<div class="table-responsive">
<table class="jh-table table table-striped">
<thead>
<tr jh-sort="vm.predicate" ascending="vm.reverse" callback="vm.reset()">
<th jh-sort-by="id"><span>ID</span> <span class="glyphicon glyphicon-sort"></span></th>
<th jh-sort-by="check"><input type="checkbox" ng-model="vm.selectedAll" ng-click="vm.checkAll[vm.page]" /></th>
<th jh-sort-by="bankName"><span>Bank Name</span> <span class="glyphicon glyphicon-sort"></span></th>
<th jh-sort-by="rejectedRemarks"><span>Rejected Remarks</span> <span class="glyphicon glyphicon-sort"></span></th>
<th></th>
</tr>
</thead>
<tbody infinite-scroll="vm.loadPage(vm.page + 1)" infinite-scroll-disabled="vm.page >= vm.links['last']">
<tr ng-repeat="hdfc in vm.hdfcs track by hdfc.id">
<td><a ui-sref="hdfc-detail({id:hdfc.check})">{{hdfc.check}}</a></td>
<td><input type="checkbox" ng-model="vm.checkboxes[hdfc.id]" ng-change="vm.select(hdfc)"/></td>
<td>{{($index + 1) + (vm.page - 1) * vm.itemsPerPage}}</td>
<td>{{hdfc.bankName}}</td>
<td>{{hdfc.rejectedRemarks}}</td>
<td class="text-right">
<div class="btn-group flex-btn-group-container">
<button type="submit"
ui-sref="hdfc-detail({check:hdfc.check})"
class="btn btn-info btn-sm">
<span class="glyphicon glyphicon-eye-open"></span>
<span class="hidden-xs hidden-sm"></span>
</button>
<button type="submit"
ui-sref="hdfc.edit({check:hdfc.check})"
class="btn btn-primary btn-sm">
<span class="glyphicon glyphicon-pencil"></span>
<span class="hidden-xs hidden-sm"></span>
</button>
<button type="submit"
ui-sref="hdfc.delete({check:hdfc.check})"
class="btn btn-danger btn-sm">
<span class="glyphicon glyphicon-remove-circle"></span>
<span class="hidden-xs hidden-sm"></span>
</button>
</div>
</td>
</tr>
</tbody>
</table>
</div>
` ID 銀行名稱 拒絕備註刪除記錄 = vm.links [ '最後']「> {{hdfc.check}} {{($索引+ 1)+(vm.page - 1)* vm.itemsPerPage}} {{HDFC。 BANKNAME}} {{hdfc.rejectedRemarks}}
定義 '不工作'? – Matheno
這意味着當我點擊表格標題中的複選框時(對於選中所有複選框),那麼它會報錯:internalservererror – Atul
以及如何使用複選框刪除行或行 – Atul