Как сделать группы кнопок Twitter Bootstrap работать с AngularJS?
Я пытаюсь создать простую группу twitter bootstrap button, которая позволяет пользователю выбрать один из нескольких вариантов (подумайте о переключателях). У меня есть это до такой степени, что это влияет на изменения в модели, но "активное" состояние неправильно установлено onclick... если я не нажму второй раз? Я создал скрипку, а основная разметка...
<div range="justified"
model="myModel"
options="rangeOptions"></div>
<hr/>
<div range="vertical"
model="myModel"
options="rangeOptions"></div>
<hr/>
<pre>myModel:{{myModel}}</pre>
<script type="text/ng-template" id="range.tpl.html">
<div class="btn-group btn-group-{{type}}" data-toggle="buttons">
<span class="btn btn-lg btn-primary"
ng-repeat="option in options"
ng-class="{active:option.id==model.range_id}" <!-- not working?? -->
ng-click="activate(option.id)">{{option.label}}</span>
</div>
</script>
function Main($scope) {
$scope.rangeOptions = [
{id:1,label:"Agree"},
{id:2,label:"Neutral"},
{id:3,label:"Disagree"}
];
$scope.myModel = {range_id: 2};
}
angular
.module('range', [])
.directive('range', function () {
return {
replace: true,
scope: { type:'@range', model:'=', options:'=' },
templateUrl:'range.tpl.html',
controller: function ($scope,$element,$attrs) {
$scope.activate = function (option) {
$event.preventDefault();
};
}
};
});
Ответы
Ответ 1
Вам не нужно 90% bootstrap js, чтобы заставить все, что угодно, работать, все, что вам нужно сделать, это создать группу кнопок и прикрепить к ней ng-клики и ng-класс:
function myscope($scope) {
$scope.button = 'red';
}
<div class="btn-group">
<a href="javascript:void(0)" ng-click="button = 'red'" ng-class="{ 'active' : button == 'red' }" class="btn">red</a>
<a href="javascript:void(0)" ng-click="button = 'blue'" ng-class="{ 'active' : button == 'blue' }" class="btn">blue</a>
<a href="javascript:void(0)" ng-click="button = 'green'" ng-class="{ 'active' : button == 'green' }" class="btn">green</a>
</div>
Ответ 2
Здесь есть дополнительная информация о том, как ваша группа кнопок работает как переключатели.
http://getbootstrap.com/javascript/#buttons
Используя эту информацию, я разблокировал свой скрипт и, похоже, работает.
http://jsfiddle.net/puatj/
Изменение заключалось в том, чтобы переключить ваш элемент span на метку/ввод.
<div class="btn-group btn-group-{{type}}" data-toggle="buttons">
<label class="btn btn-lg btn-primary"
ng-repeat="option in options"
ng-class="{active:option.id==model.range_id}"
ng-click="activate(option.id)"><input type="radio"></input>{{option.label}}</label>
</div>
Ответ 3
Если вы не возражаете отказаться от небольшого стильного стиля бутстрапа, вы можете исправить это, просто вытащив тег переключения данных
<div ng-app>
<h1>{{color}}</h1>
<form>
<div>
<label>Select a Color</label>
</div>
<div class="btn-group">
<label class="btn btn-primary">
<input type="radio" name="color" data-ng-model="color" value="'red'"> Red
</label>
<label class="btn btn-primary">
<input type="radio" name="color" data-ng-model="color" value="'green'"> Green
</label>
<label class="btn btn-primary">
<input type="radio" name="color" data-ng-model="color" value="'blue'"> Blue
</label>
<label class="btn btn-primary">
<input type="radio" name="color" data-ng-model="color" value="'black'"> Black
</label>
<label class="btn btn-primary">
<input type="radio" name="color" data-ng-model="color" value="'orange'"> Orange
</label>
</div>
</form>
</div>
Здесь вы можете найти JSFiddle.
Ответ 4
Оставьте данные-toggle = "buttons" из родительского div и добавьте класс или стиль во входы, которые задают ширину свойств: 0px и видимость: hidden.
Чтобы отображать кнопки как активные, используйте ng-init, ng-click и ng-class для переключения активных классов.
<label>Location</label><br/>
<div class="btn-group" ng-init="selectedButton = 'all'">
<label class="btn btn-default active" ng-class="{'active':selectedButton === 'all'}" ng-click="selectedButton = 'all'">
<input type="radio" name="inlineRadioOptions" id="inlineRadio1" value="all" ng-model="filterData.locations" checked style="visibility:hidden; width:0px;" > All Locations
</label>
<label class="btn btn-default" ng-class="{'active':selectedButton === 'boroughs'}" ng-click="selectedButton = 'boroughs'">
<input type="radio" name="inlineRadioOptions" id="inlineRadio2" value="boroughs" ng-model="filterData.locations" style="visibility:hidden; width:0px;" > Boroughs
</label>
<label class="btn btn-default" ng-class="{'active':selectedButton === 'depots'}" ng-click="selectedButton = 'depots'">
<input type="radio" name="inlineRadioOptions" id="inlineRadio3" value="depots" ng-model="filterData.locations" style="visibility:hidden; width:0px;" > Depots
</label>
</div>
Ответ 5
Я нашел способ angular для этого, непосредственно из массива в вашем контроллере.
<div class="btn-group" data-toggle="buttons">
<label class="btn btn-tertiary" ng-class="{active: availableOption === searchFieldsContent.searchOption}" ng-repeat="availableOption in searchOptions">
<input type="radio" name="searchOption" id="searchOption{{$index}}" ng-model="searchFieldsContent.searchOption" ng-value="availableOption">{{availableOption.name}}</input>
</label>
</div>