AngularおよびTwitter Bootstrap navbarを使用して、折りたたみ機能を機能させようとしています。
部分:program.html
<div class="navbar navbar-inverse navbar-static-top" ng-include="'partials/navbar.html'" ng-controller="NavbarCtrl"></div>
部分:navbar.html
<div class="navbar-inner">
<div class="container">
<a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</a>
<a class="brand" href="#">Short Course</a>
<div class="nav-collapse collapse">
<ul class="nav">
<li><a href="#"><i class="icon-home icon-white"></i> Home</a></li>
<li class="dropdown ng-class: settingsActive;">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Intro <b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a onclick='$("#myModal").modal("show");'>User Info</a></li>
<li><a href="#/setup">Settings</a></li>
<li><a href="#/get-started">Getting started</a></li>
</ul>
</li>
<li class="dropdown ng-class: programActive;" ng-controller="ProgramCtrl">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Lessons <b class="caret"></b></a>
<ul class="dropdown-menu">
<li ng-repeat='o in lessonTypes'>
<a href="#/program/{{o.value}}">{{o.title}}</a>
</li>
<li class="divider"></li>
<li><a href="#/freeform">Free Form</a></li>
</ul>
</li>
<li class="dropdown ng-class: reportsActive;">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Grades <b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a href="#">Simple Report</a></li>
<li><a href="#">Comprehensive Report</a></li>
<li class="divider"></li>
<li><a href="#">Current Grade Report</a></li>
<li><a href="#">Final Grade Report</a></li>
</ul>
</li>
</ul>
<ul class="nav pull-right">
<li><a href="#/class"><i class="icon-upload icon-white"></i> Upload/Save</a></li>
<li><a href="#/class"><i class="icon-off icon-white"></i> Save/Logout</a></li>
</ul>
</div><!-- /.nav-collapse -->
</div>
</div><!-- /navbar-inner -->
Navbarは完全に表示されます。ドロップダウンは素晴らしい働きをします。 Angular関数はデータをロードし、特定のアイテムをアクティブとしてマークし、モデルに完全に入力します。動作しない唯一のことは、レスポンシブな折りたたみ機能です。画面のサイズを変更すると、メニュー項目が消えてメニューのアイコンが表示されますが、クリックしても機能しません。私はこれにこだわっており、簡単な修正である必要があることを知っていますが、私はそれを理解することができません。助けていただければ幸いです!
これは難しいものでした。ドキュメントは1つの方法を示し、それは素晴らしい機能をします。ドキュメントのサンプルをコピーし( http://Twitter.github.com/bootstrap/components.html#navbar )、それを使用してみました。次に、サンプルページに移動して、ここにリストされているレイアウトを試しました。 http://Twitter.github.com/bootstrap/examples/fluid.html
唯一の違いは、<button>
の代わりに<a>
でした
<button type="button" class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
の代わりに
<a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
理由はわかりませんが、変更することで機能が向上しました。
EDIT
アービターは、<a />
にhref='#'
属性が欠落していることを指摘しました。その属性を追加すると、問題も解決します。
興味のある人のために-Bootstrapのjavascriptなしでこれを実装する別の方法を次に示します。
Angularのインポート UIブートストラップ。
HTML:
<div class="navbar navbar-inverse" ng-controller="NavBarCtrl">
<div class="navbar-inner">
<div class="container">
<button class="btn btn-navbar" ng-click="isCollapsed = !isCollapsed">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button> <a class="brand" href="#">Short Course</a>
<div class="nav-collapse" uib-collapse="isCollapsed">
<ul class="nav">
<li><a href="#"><i class="icon-home icon-white"></i> Home</a>
</li>
<li><a href="#">Lessons</a>
</li>
<li><a href="#">Grades</a>
</li>
</ul>
<ul class="nav pull-right">
<li><a href="#/class"><i class="icon-upload icon-white"></i> Upload/Save</a>
</li>
<li><a href="#/class"><i class="icon-off icon-white"></i> Save/Logout</a>
</li>
</ul>
</div>
<!-- /.nav-collapse -->
</div>
</div>
<!-- /navbar-inner -->
</div>
JS:
var myApp = angular.module('myApp', ['ui.bootstrap']);
function NavBarCtrl($scope) {
$scope.isCollapsed = true;
}
そしてフィドル- http://jsfiddle.net/KY5Mf/
純粋なAngularJSで動作させ、それ以上のJavaScriptライブラリは不要であり、非常にシンプルであることが判明しました。 ここの例 (ブートストラップv3)で始まる2つの変更のみが必要です。
の代わりに
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
私が使用した:
<button type="button" class="navbar-toggle" ng-init="isCollapsed = true" ng-click="isCollapsed = !isCollapsed">
代わりに
<div class="collapse navbar-collapse">
私が使用した:
<div class="navbar-collapse" ng-class="{collapse: isCollapsed}">
また、ナビゲーションバーにドロップダウンメニューがある場合、cssクラスが「折りたたみ」ではなく「開く」ことを除き、同じことが適用されます。
<li class="dropdown" ng-class="{ open : dd1 }" ng-init="dd1 = false" ng-click="dd1 = !dd1">
複数のドロップダウンはすべて、angularルートスコープの独自の状態変数を必要とすることに注意してください(コントローラーを使用していない場合)。したがって、ここでは最初のドロップダウンに「dd1」という名前を付けました。一意である必要があります。そうしないと、複数のドロップダウンが同時に開閉します。 (これはかなり面白いですが、めったに使用できません)。
コントローラーを使用する必要はありません。テンプレートを最初にコンパイルするときに、代わりにng-init
を使用してisCollapsed
フラグを初期化します。
<div class="navbar navbar-inverse" ng-controller="NavBarCtrl">
<div class="navbar-inner">
<div class="container">
<button class="btn btn-navbar" ng-init="isCollapsed = true" ng-click="isCollapsed = !isCollapsed">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button> <a class="brand" href="#">Short Course</a>
<div class="nav-collapse" collapse="isCollapsed">
<ul class="nav">
<li><a href="#"><i class="icon-home icon-white"></i> Home</a>
</li>
<li><a href="#">Lessons</a>
</li>
<li><a href="#">Grades</a>
</li>
</ul>
<ul class="nav pull-right">
<li><a href="#/class"><i class="icon-upload icon-white"></i> Upload/Save</a>
</li>
<li><a href="#/class"><i class="icon-off icon-white"></i> Save/Logout</a>
</li>
</ul>
</div>
<!-- /.nav-collapse -->
</div>
</div>
<!-- /navbar-inner -->
</div>
Angular2
を探している場合。その後、打撃が必要な変更です。
<button type="button" class="navbar-toggle collapsed" (click)="toggleCollapse()"
aria-expanded="false">
メニューは次のようになります。
<div class="navbar-collapse" id="bs-navbar-collapse" [class.collapse]="isCollapsed">
<ul class="nav navbar-nav">
<li>
<a href="">
Dashboard
コントローラーはこのようなものでなければなりません。
import { Component} from '@angular/core';
@Component({
selector: 'app-navbar',
templateUrl: './navbar.component.html',
styleUrls: ['./navbar.component.css']
})
export class NavbarComponent {
isCollapsed: boolean = true;
toggleCollapse(): void {
this.isCollapsed = !this.isCollapsed;
}
}
angular2
ではこれは比較的簡単です。答えてくれた@yankeeに感謝します。
以下は、ui.bootstrap.collapseモジュールを使用した実用的な実装です。 https://jsfiddle.net/7z8hLuyu/
HTML
<div ng-app="app">
<nav class="navbar navbar-default">
<div class="container-fluid" ng-controller="NavigationCtrl as vm">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle" ng-click="vm.toggleCollapse()">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">Brand</a>
</div>
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="navbar-collapse" style="overflow:hidden!important;" uib-collapse="vm. isCollapsed">
<ul class="nav navbar-nav">
<li class="active"><a href="#">Link <span class="sr-only">(current)</span></a></ li>
<li><a href="#">Link</a></li>
<li><a href="#">Link 2</a></li>
<li><a href="#">Link 3</a></li>
<li><a href="#">Link 4</a></li>
</ul>
</div><!-- /.navbar-collapse -->
</div><!-- /.container-fluid -->
</nav>
</div>
コントローラー(controllerAs構文を使用):
(function(){
'use strict';
angular
.module('app', ['ngAnimate','ui.bootstrap.collapse'])
.controller('NavigationCtrl', NavigationCtrl);
NavigationCtrl.$inject = [];
function NavigationCtrl() {
var vm = this;
vm.isCollapsed = true;
vm.toggleCollapse = toggleCollapse;
function toggleCollapse() {
vm.isCollapsed = !vm.isCollapsed;
}
}
})();
注:ui.bootstrapモジュールでアニメーションを機能させるには、ngAnimateを含める必要があります。
jquery.min.jsおよびbootstrap.min.jsをindex.htmlファイルに追加するだけでこの問題は解決しました。
折りたたみ可能なナビゲーションの場合、jquery.min.jsおよびbootstrap.min.jsを含める必要があります
これは単純なJS修正になると思います。
//for close, opened dropdown.
$(".nav a").click(function () {
if ($(".navbar-collapse").hasClass("in")) {
$('[data-toggle="collapse"]').click();
}
});
このコードが正しく機能しない場合は、コードが正しくバインドされていることを確認して、ページをロードするコントローラーに配置してください。