Вы можете разбить массив на два массива или с помощью директивы углового предела - создать два ULS.Он повторяет разметку - но он позволяет вам иметь два UL, которые затем могут отображаться горизонтально с помощью flex и flex-direction на меньших экранах, а на больших экранах с помощью flex-direction - row - могут отображать две ul рядом друг с другом.
Запустите фрагмент ниже и включите и выключите «Полноэкранный режим» - у меня есть медиа-запрос, который изменяет направление гибкого изменения размера окна просмотра.
РЕДАКТИРОВАТЬ - я добавил кнопку переключения, которая искусственнопереключает класс, чтобы можно было увидеть различные выравнивания при нажатии кнопки hte.
angular.module('app',['ui.bootstrap'])
.controller('mainCtrl', function() {
var vm = this;
vm.columnOrientation = false;
vm.toggleListOrientation = function() {
vm.columnOrientation = !vm.columnOrientation;
}
vm.alertFilters = [
{ key: 'MOT Due', value: 1 },
{ key: 'Insurance Due', value: 2 },
{ key: 'Service Due', value: 3 },
{ key: 'Licence Due', value: 4 },
{ key: 'RFL Due', value: 5 },
{ key: 'Renewals Due', value: 6 },
{ key: 'Active Complaints', value: 7 },
{ key: 'Include all Customers', value: 8 }
];
})
.list-wrapper {
display: flex;
flex-direction: column;
}
@media (min-width: 992px) {
.list-wrapper {
flex-direction: row;
}
}
.list-wrapper.showAsRow {
flex-direction: row;
}
ul {
list-style: none;
margin-bottom: 0!important
}
<html ng-app="app">
<head>
<link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.css"/>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.7.5/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/2.5.0/ui-bootstrap.min.js"></script>
</head>
<body>
<div ng-controller="mainCtrl as vm">
<button type="button" class="btn btn-default btn-xs pull-right" ng-click="vm.toggleListOrientation()"> Click to toggle the lists</button>
<form>
<label class="control-label">Alert Filters</label>
<div class="list-wrapper" ng-class="{'showAsRow': vm.columnOrientation}">
<ul class="first-four">
<li ng-repeat="alertFilter in vm.alertFilters | limitTo:4:0" class="first-four">
<input type="checkbox" name="alertsFilter" id="alertsFilter{{::$id}}" ng-value="alertFilter.value">
<label for="alertsFilter{{::$id}}" ng-bind="alertFilter.key" class="alertLabel"></label>
</li>
</ul>
<ul class="second-four">
<li ng-repeat="alertFilter in vm.alertFilters | limitTo:4:4" class="first-four">
<input type="checkbox" name="alertsFilter" id="alertsFilter{{::$id}}" ng-value="alertFilter.value">
<label for="alertsFilter{{::$id}}" ng-bind="alertFilter.key" class="alertLabel"></label>
</li>
</ul>
</div>
</form>
</div>
</body>
</html>