私はAngularJSを初めて使用し、2つの異なるHTMLパーシャルをロードするリストとグリッドビュートグルスイッチボタンの特定のチュートリアルを見つけることができませんでした。公式を読むng-include
、ng-switch
公式ドキュメントと検索SO。残念ながら、 I-router は使用しません。
2つのパーシャルでロードしています(list.html
およびgrid.html
)正しいAngularこれをコーディングする方法は?
私が見つけた最も関連性のあるヘルプは次のとおりです。
1 . http://tutorialzine.com/2013/08/learn-angularjs-5-examples (例#5)
例5に洞察に満ちたコメントがありました
素敵な簡単な例-よくできました。グリッドビューとリストビューを切り替える最後の例は、オプションを作成し、オプションを表示/非表示にするため、あまり効率的ではありません。より単純でより良いアプローチは、リピーターとng-switchを備えた単一のulを使用し、次にng-switch-caseを使用して代替リスト要素を有効にすることです。 -ヨハン
2 . http://www.Adobe.com/devnet/html5/articles/getting-started-with-angularjs.html
3 . angularjsの複数の部分ビューに対して単一のhtmlビューを作成します
私のHTMLコード
<div class="col-xs-6" ng-controller="ToggleDisplayCtrl">
<div class="btn-group select-format-container" ng-switch on="selected">
<button ng-switch-when="true" ng-click="toggleGrid()" type="button" class="btn btn-primary" ng-model="formatChoice" ng-disabled="">grid</button>
<button ng-switch-when="false" ng-click="toggleList()" type="button" class="btn btn-primary" ng-model="formatChoice" ng-disabled="">list</button>
</div>
<div ng-include src="formatChoice.url" scope="" onload=""></div>
</div><!-- col-xs-6 END ToggleDisplayCtrl-->
私のディレクティブコード
'use strict';
var app = angular.module('tempApp');
app.controller('ToggleDisplayCtrl', function($scope) {
$scope.formatChoices =
[ { name: 'grid', url: 'partials/grid.html'},
{ name: 'list', url: 'partials/list.html'} ];
$scope.selected = true;
$scope.toggleGrid = function() {
if(selected) {
return "partials/grid.html";
}
return "main.html";
};
$scope.toggleList = function() {
if(selected) {
return "partials/list.html";
}
return "main.html";
};
});
ng-include
のテンプレートのURLを保持するアプリケーションコントローラーのスコーププロパティを定義し、このプロパティをディレクティブのスコープにバインドする必要があります。ディレクティブのスコープを変更する際の副作用を回避するために、ディレクティブでは必ず分離スコープを使用してください。これを行う例を次に示します(コードのコメントを参照)。
JavaScript
angular.module('app',['ngRoute']).
config(['$routeProvider', function($routeProvider){
$routeProvider.
when('/main', {
controller: 'appController',
templateUrl: 'main.html'
}).
otherwise({
redirectTo: '/main'
});
}]).
controller('appController', ['$scope', function($scope){
$scope.view = 'list.html'; // <- default template used for ng-include
$scope.data = [{
text: '1'
}, {
text: '2'
}, {
text: '3'
}, {
text: '4'
}, {
text: '5'
}, {
text: '6'
}];
}]).
directive('appView', function() {
return {
scope: {
view: '=appView' // <= link view property of directive's scope to some property in the parent scope (scope of appController) specified in app-view attribute of root element of directive
},
replace: true,
template: '<nav class="navbar navbar-default">' +
'<div class="container">' +
'<ul class="nav navbar-nav navbar-right">' +
'<li ng-repeat="v in views" ng-bind="v.name" ng-class="v.icon" ng-click="switchView(v)"></li>' +
'</ul>' +
'</div>' +
'</nav>',
link: function(scope, el, attr) {
scope.views = [{
name: 'List',
template: 'list.html',
icon: 'btn btn-default navbar-btn glyphicon glyphicon-th-list'
}, {
name: 'Grid',
template: 'grid.html',
icon: 'btn btn-default navbar-btn glyphicon glyphicon-th'
}];
},
controller: ['$scope', function($scope){
$scope.switchView = function(view) {
$scope.view = view.template; // <- modify parent scope view
}
}]
}
});
アプリケーションのメインページ(index.html)
<html ng-app="app">
...
<body ng-view=""></body>
</html>
ルートテンプレート(main.html)
<header app-view="view"></header>
<section ng-include="view"></section>
リストビューテンプレート(list.html)
<div class="container">
<div class="row">
<div class="col-md-12 col-sm-12 panel panel-default" ng-repeat="item in data">
<div class="panel-body">{{item.text}}</div>
</div>
</div>
</div>
グリッドビューテンプレート(grid.html)
<div class="container">
<div class="row">
<div class="col-md-4 col-sm-6 panel panel-default" ng-repeat="item in data">
<div class="panel-body">{{item.text}}</div>
</div>
</div>
</div>
プランカー: http://plnkr.co/edit/uWw7NuPG0I161mHXZg2r?p=preview
ボーナス:グリッドはレスポンシブです。ウィンドウサイズで少し遊んでください
別のオプション:
お気づきかもしれませんが、grid.html
とlist.html
は非常に似ているため、これら2つのオプションしかない場合は、ng-include
を個別の切り替え可能なビューで使用せず、コンテンツを配置することを決定できます。ルートのテンプレートを直接表示し、ビューが変更されたときにクラスを切り替えることができるng-class
ディレクティブを使用して、パネルで使用されるクラスを切り替えるだけです。
ルートテンプレート(main.html)
<header app-view="view"></header>
<section>
<div class="container">
<div class="row">
<div ng-class="{'col-md-4': view === 'grid.html', 'col-md-12': view === 'list.html', 'panel':true, 'panel-default':true}" ng-repeat="item in data">
<div class="panel-body">{{item.text}}</div>
</div>
</div>
</div>
</section>
簡単に機能するJSBinは次のとおりです。 http://jsbin.com/jomiquqi/1/edit
_ng-include
_ディレクティブは、テンプレートに含める変数を取ります。したがって、コードを更新して機能させるには、toggleGrid()
メソッドが何かを返すのではなく、私の例のように_ng-include
_に渡すスコープに変数を設定する必要があります。
基本的にあなたがする必要があるのは、リストビューとグリッドを同じページに同時に配置し、一度に1つずつ表示し、スイッチボタンでそれらを切り替える(cssクラスを変更する)ことです。ここで例5について説明します。
スコープ内の最初のレイアウト変数
$scope.layout = 'grid';
こちらがスイッチボタンです
<!-- On click change "$scope.layout = list" and if layout=='list' add class 'active' to self-->
<a href="#" class="list-icon" ng-class="{active: layout == 'list'}" ng-click="layout = 'list'"></a>
<!-- On click change "$scope.layout = grid" and if layout=='grid' add class 'active' to self-->
<a href="#" class="grid-icon" ng-class="{active: layout == 'grid'}" ng-click="layout = 'grid'"></a>
これらはグリッドブロックとリストブロックです。
<!-- Layout=='grid' if layout parameter is grid than show this block -->
<ul ng-show="layout == 'grid'" class="grid">...</ul>
<!-- Layout=='list' if layout parameter is list than show this block -->
<ul ng-show="layout == 'list'" class="list">...</ul>
リストとグリッドレイアウトを作成するCSS
/*-------------------------
List layout
--------------------------*/
ul.list{
list-style: none;
width: 500px;
margin: 0 auto;
text-align: left;
}
ul.list li{
border-bottom: 1px solid #ddd;
padding: 10px;
overflow: hidden;
}
ul.list li img{
width:120px;
height:120px;
float:left;
border:none;
}
ul.list li p{
margin-left: 135px;
font-weight: bold;
color:#6e7a7f;
}
/*-------------------------
Grid layout
--------------------------*/
ul.grid{
list-style: none;
width: 570px;
margin: 0 auto;
text-align: left;
}
ul.grid li{
padding: 2px;
float:left;
}
ul.grid li img{
width:280px;
height:280px;
display:block;
border:none;
}
リストとグリッドビューを表示するためのトグルアクションの理解を深めるには: このリンクをたどってください そしてこれがお役に立てば幸いです。
これを実験している場合は、これでJqueryを使用しました。これを配置してください:<script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
これを行う最も簡単な方法は次のとおりです。
<div class = "bar">
<h1>Contacts</h1>
<a href="#" class="list-icon" ng-class="{active: layout == 'list'}" ng-click="layout = 'list'"></a>
<a href="#" class="grid-icon" ng-class="{active: layout == 'grid'}" ng-click="layout = 'grid'"></a>
</div>
<div ng-show="layout == 'list'" class="list">
//Add your list page here
<div ng-show="layout == 'grid'" class="grid">
//Add your grid page here
CSS:
/*
Contacts bar with toggle switches
*/
.bar{
background-color: #5c9bb7;
background-size: 100% 100%;
box-shadow: 0 1px 1px #ccc;
border-radius: 2px;
height: 100px;
padding: 10px;
position: relative;
text-align: right;
line-height: 1;
}
.bar a{
background:#4987a1 center center no-repeat;
width:32px;
height:32px;
display:inline-block;
text-decoration:none !important;
margin-right:5px;
border-radius:2px;
}
.bar a.active{
background-color:#c14694;
}
.bar a.list-icon{
background- image:url( GXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOkYzNkFCQ0ZBMTBCRTExRTM5NDk4RDFEM0E5RkQ1NEZCIiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOkYzNkFCQ0ZCMTBCRTExRTM5NDk4RDFEM0E5RkQ1NEZCIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6RjM2QUJDRjgxMEJFMTFFMzk0OThEMUQzQTlGRDU0RkIiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6RjM2QUJDRjkxMEJFMTFFMzk0OThEMUQzQTlGRDU0RkIiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz7h1bLqAAAAWUlEQVR42mL8////BwYGBn4GCACxBRlIAIxAA/4jaXoPEkMyjJ+A/g9MDJQBRhYg8RFqMwg8RJIUINYLFDmBUi+ADQAF1n8ofk9yIAy6WPg4GgtDMRYAAgwAdLYwLAoIwPgAAAAASUVORK5CYII=);
}
.bar a.grid-icon{
background-image:url();
}
/*-------------------------
List layout
--------------------------*/
ul.list{
list-style: none;
width: 500px;
margin: 0 auto;
text-align: left;
}
ul.list li{
border-bottom: 1px solid #ddd;
padding: 10px;
overflow: hidden;
}
ul.list li img{
width:120px;
height:120px;
float:left;
border:none;
}
ul.list li p{
margin-left: 135px;
font-weight: bold;
color:#6e7a7f;
}
/*-------------------------
Grid layout
--------------------------*/
ul.grid{
list-style: none;
width: 570px;
margin: 0 auto;
text-align: left;
}
ul.grid li{
padding: 2px;
float:left;
}
ul.grid li img{
width:280px;
height:280px;
display:block;
border:none;
}