Привязка значений смарт-таблиц и редактирование строк
Разработка страницы с использованием углового умного стола.
Необходимо добавить новые строки в таблицу, в настоящее время новые строки добавляются в конце. Как я могу добавить строки в начале таблицы?
Это HTML-страница
<style>
.sortable {
cursor: pointer;
}
.sortable:after {
content: url();
padding-left: 1em;
}
.st-sort-ascent:after {
content: '\25B2';
}
.st-sort-descent:after {
content: '\25BC';
}
</style>
<div ng-controller="AppSettingsController as appCtrl">
<button type="button" ng-click="addRandomItem(row)" class="btn btn-sm btn-success">
<i class="glyphicon glyphicon-plus">
</i> Add random item
</button>
<table st-table="displayedCollection" st-safe-src="rowCollection" class="table table-striped">
<thead>
<tr>
<th class="sortable" st-sort="parameterkey">Parameter Key</th>
<th class="sortable" st-sort="description">Description</th>
<th class="sortable" st-sort="value">Value</th>
<th class="sortable" st-sort="type">Type</th>
<th class="sortable" st-sort="active">Active</th>
<th class="sortable" st-sort="action">Action</th>
</tr>
<tr>
<th colspan="6"><input st-search="" class="form-control" placeholder="global search ..." type="text"/></th>
</tr>
</thead>
<tbody>
<tr ng-repeat="row in displayedCollection">
<td editable-text="row.key" ng-model="appCtrl.param.key">{{row.key}}</td>
<td>{{row.description}}</td>
<td>{{row.value}}</td>
<td>{{row.type}}</td>
<td>{{row.activeYn}}</td>
<td>
<button type="button" ng-click="removeItem(row)" class="btn btn-sm btn-danger">
<i class="glyphicon glyphicon-remove-circle">
</i>
</button>
</td>
</tr>
</tbody>
</table>
<div style="padding-bottom: 10px; padding-left: 5px; padding-right: 5px;">
<button class="btn btn-primary" type="submit"
style="float: right; margin-right: 5px;" ng-click="appCtrl.save()">Submit</button>
</div>
</div>
Это страница JS
(function () {
'use strict';
angular.module('app.controllers')
.controller("AppSettingsController", AppSettingsController);
AppSettingsController.$inject = ['$scope','$http','LookupService','$filter'];
function AppSettingsController($scope,$http,LookupService,$filter){
var vm = this;
vm.param={};
$http({
method: 'GET',
url: 'param/getAllAppParam',
}).then(function(resp){
if(resp.data.result != null && resp.data.result != undefined && resp.data.code == 0 && resp.data.result!=false){
$scope.rowCollection = [];
$scope.rowCollection = resp.data.result;
$scope.displayedCollection = [].concat(vm.rowCollection);
}
else{
vm.successMsg = "";
vm.errorMsg = "Error occured in Server..!User Could not be saved..!";
console.log(vm.errorMsg);
vm.saved = false;
}
});
//copy the references (you could clone ie angular.copy but then have to go through a dirty checking for the matches)
// $scope.displayedCollection = [].concat($scope.rowCollection);
//add to the real data holder
$scope.addRandomItem = function addRandomItem() {
$scope.rowCollection.push({
"paramId": "",
"value": "",
"activeYn": "",
"description": "",
"type": "",
"query": "",
"key": ""
});
};
//remove to the real data holder
$scope.removeItem = function removeItem(row) {
var index = $scope.rowCollection.indexOf(row);
if (index !== -1) {
$scope.rowCollection.splice(index, 1);
}
}
vm.save = function(){
console.log("here");
console.log(JSON.stringify(vm.param));
}
}
})();
1 ответ
Вы должны использовать unshift
вместо push
$scope.addRandomItem = function addRandomItem() {
$scope.rowCollection.unshift({
"paramId": "",
"value": "",
"activeYn": "",
"description": "",
"type": "",
"query": "",
"key": ""
});
};