我正在使用Angular-Material并已实施SideNav菜单。当屏幕尺寸很小时,菜单被隐藏,当点击菜单切换按钮时,菜单从左侧滑出,具有整页高度。当屏幕较大时,菜单固定在左侧,但不是全页高度。如何使用Angular-Material获得完整高度的sidenav
如何使固定菜单显示为整页高度。 我一直在玩css和其他md属性,但只是无法找到如何。
<div ng-controller="appCtrl" layout="vertical" layout-fill>
<md-toolbar class="md.medium-tall app-toolbar">
<div class="md-toolbar-tools" ng-click="toggleMenu()">
<button class="menu-icon" hide-sm aria-label="Toggle Menu">
<md-icon icon="img/icons/ic_menu_24px.svg">
<object class="md-icon" data="img/icons/ic_menu_24px.svg"></object>
</md-icon>
</button>
<h2>
<span>Dev.Material</span>
</h2>
</div>
</md-toolbar>
<section layout="horizontal" flex>
<md-sidenav class="md-sidenav-left md-whiteframe-z2" component-id="menu" is-locked-open="$media('sm')">
<md-toolbar md-theme="purple">
<h1 class="md-toolbar-tools">Sidenav Left</h1>
</md-toolbar>
<md-content class="md-padding" ng-controller="menuCtrl">
<p>
This sidenav is locked open on your device. To go back to the default behavior,
narrow your display.
</p>
</md-content>
</md-sidenav>
<md-content flex class="md-padding">
Some content !!
</md-content>
和控制器:
(function() {
'use strict';
var controllerId = 'appCtrl';
angular.module('app').controller(controllerId,
['$scope', '$timeout', '$mdSidenav', appCtrl]);
function appCtrl($scope, $timeout, $mdSidenav) {
var vm = this;
$scope.toggleMenu = function() {
$mdSidenav('menu').toggle();
};
};
})();
(function() {
'use strict';
var controllerId = 'menuCtrl';
angular.module('app').controller(controllerId,
['$scope', '$timeout', '$mdSidenav', menuCtrl]);
function menuCtrl($scope, $timeout, $mdSidenav) {
var vm = this;
$scope.close = function() {
$mdSidenav('menu').close();
};
};
})();
您可能想要包括您期望在此支持的浏览器...有可能使用vh(视口高度)的解决方案,但这在旧版本的CSS中不可用。或者,您可以使用一个指令来监视任何调整大小的事件,并使用offsetHeight或者screen.height捕获元素的更新高度并将其存储在某个地方(值或服务或工厂) – shaunhusain 2014-11-01 14:06:52