AngularMaterial-レイアウト
レイアウト指令
コンテナ要素のレイアウトディレクティブは、その子のレイアウト方向を指定するために使用されます。レイアウト指令に割り当て可能な値は次のとおりです-
row −アイテムは、max-height = 100%で水平に配置され、max-widthはコンテナ内のアイテムの幅です。
column −アイテムは、max-width = 100%で垂直に配置され、max-heightはコンテナ内のアイテムの高さです。
デバイスの画面サイズに応じてレイアウトなどのレスポンシブデザインを自動変更する場合は、次の表に示すレイアウトAPIを使用して、ビュー幅のあるデバイスのレイアウト方向を設定できます。
シニア番号 | ブレークポイントがデフォルトをオーバーライドするときのAPIとデバイスの幅 |
---|---|
1 | layout 別のブレークポイントによってオーバーライドされない限り、デフォルトのレイアウト方向を設定します。 |
2 | layout-xs 幅<600px |
3 | layout-gt-xs 幅> = 600px |
4 | layout-sm 600px <=幅<960px |
5 | layout-gt-sm 幅> = 960px |
6 | layout-md 960px <=幅<1280px |
7 | layout-gt-md 幅> = 1280px |
8 | layout-lg 1280px <=幅<1920px |
9 | layout-gt-lg 幅> = 1920px |
10 | layout-xl 幅> = 1920px |
例
次の例は、layoutディレクティブの使用法とlayoutの使用法を示しています。
am_layouts.htm
<html lang = "en">
<head>
<link rel = "stylesheet"
href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
<link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
<style>
.box {
color:white;
padding:10px;
text-align:center;
border-style: inset;
}
.green {
background:green;
}
.blue {
background:blue;
}
</style>
<script language = "javascript">
angular
.module('firstApplication', ['ngMaterial'])
.controller('layoutController', layoutController);
function layoutController ($scope) {
}
</script>
</head>
<body ng-app = "firstApplication">
<div id = "layoutContainer" ng-controller = "layoutController as ctrl"
style = "height:100px;" ng-cloak>
<div layout = "row" layout-xs = "column">
<div flex class = "green box">Row 1: Item 1</div>
<div flex = "20" class = "blue box">Row 1: Item 2</div>
</div>
<div layout = "column" layout-xs = "column">
<div flex = "33" class = "green box">Column 1: item 1</div>
<div flex = "66" class = "blue box">Column 1: item 2</div>
</div>
</div>
</body>
</html>
結果
結果を確認します。
フレックス指令
コンテナ要素のflexディレクティブは、要素のサイズと位置をカスタマイズするために使用されます。これは、要素がその親コンテナおよびコンテナ内の他の要素に対してサイズを調整する方法を定義します。以下は、flexディレクティブに割り当て可能な値です-
multiples of 5 − 5、10、15 ... 100
33 − 33%
66 − 66%
例
次の例は、flexディレクティブの使用法とflexの使用法を示しています。
am_flex.htm
<html lang = "en">
<head>
<link rel = "stylesheet"
href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
<link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
<style>
.box {
color:white;
padding:10px;
text-align:center;
border-style: inset;
}
.green {
background:green;
}
.blue {
background:blue;
}
</style>
<script language = "javascript">
angular
.module('firstApplication', ['ngMaterial'])
.controller('layoutController', layoutController);
function layoutController ($scope) {
}
</script>
</head>
<body ng-app = "firstApplication">
<div id = "layoutContainer" ng-controller = "layoutController as ctrl"
layout = "row" style = "height:100px;" ng-cloak layout-wrap>
<div flex = "30" class = "green box">
[flex = "30"]
</div>
<div flex = "45" class = "blue box">
[flex = "45"]
</div>
<div flex = "25" class = "green box">
[flex = "25"]
</div>
<div flex = "33" class = "green box">
[flex = "33"]
</div>
<div flex = "66" class = "blue box">
[flex = "66"]
</div>
<div flex = "50" class = "blue box">
[flex = "50"]
</div>
<div flex class = "green box">
[flex]
</div>
</div>
</body>
</html>
結果
結果を確認します。