Mobile Angular UI - Meine erste App
In diesem Kapitel erstellen wir unsere erste App, die sowohl auf Mobilgeräten als auch auf Desktops ausgeführt werden kann.
Das im vorherigen Kapitel erstellte Projekt-Setup hat die folgende Struktur:
uiformobile/
node_modules/
src/
package.json
index.html
Befolgen Sie die Schritte, um eine einfache Benutzeroberfläche mit der Mobile Angular-Benutzeroberfläche zu erstellen.
Schritt 1
Fügen Sie die folgenden CSS-Dateien im HTML-Kopfbereich hinzu, wie unten gezeigt -
<!-- Required for desktop -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-hover.min.css" />
<!-- Mandatory CSS -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-base.min.css" />
<!-- Required for desktop -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-desktop.min.css" />
Als nächstes fügen Sie die js-Dateien hinzu -
<script src="/node_modules/angular/angular.min.js"></script>
<script src="/node_modules/angular-route/angular-route.min.js"></script>
<script src="/node_modules/mobile-angular-ui/dist/js/mobile-angular-ui.min.js"></script>
Die Datei index.html sieht folgendermaßen aus:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>My App</title>
<!-- Required for desktop -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-hover.min.css" />
<!-- Mandatory CSS -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-base.min.css" />
<!-- Required for desktop -->
<link rel="stylesheet" href="/node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-desktop.min.css" />
<script src="/node_modules/angular/angular.min.js"></script>
<script src="/node_modules/angular-route/angular-route.min.js"></script>
<script src="/node_modules/mobile-angular-ui/dist/js/mobile-angular-ui.min.js"></script>
</head>
<body>
</body>
</html>
Schritt 2
Wir werden das Grundlayout der mobilen eckigen Benutzeroberfläche wie folgt sehen:
<body ng-app="myFirstApp">
<!-- Sidebars -->
<div class="sidebar sidebar-left"><!-- ... --></div>
<div class="sidebar sidebar-right"><!-- ... --></div>
<div class="app">
<div class="navbar navbar-app navbar-absolute-top"><!-- Top Navbar --></div>
<div class="navbar navbar-app navbar-absolute-bottom"><!-- Bottom Navbar --></div>
<!-- App body -->
<div class='app-body'>
<div class='app-content'>
<ng-view></ng-view>
</div>
</div>
</div><!-- ~ .app -->
<!-- Modals and Overlays -->
<div ui-yield-to="modals"></div>
</body>
Schritt 3
Ein ... kreieren js/ folder in src/ und hinzufügen app.js dazu.
Definieren Sie das Modul und fügen Sie Mobile Angular UI und Angular Route als Abhängigkeit hinzu, wie unten gezeigt -
<script type="text/javascript">
'ngRoute',
angular.module('myFirstApp', [
'mobile-angular-ui'
]);
</script>
Fügen Sie ng-app = ”myFirstApp” zum <body> -Tag hinzu -
<body ng-app="myFirstApp">
Das mobile-angle-ui-Modul verfügt über die folgende Liste von Modulen:
angular.module('mobile-angular-ui', [
'mobile-angular-ui.core.activeLinks', /* adds .active class to current links */
'mobile-angular-ui.core.fastclick', /* polyfills overflow: auto */
'mobile-angular-ui.core.sharedState', /* SharedState service and directives */
'mobile-angular-ui.core.outerClick', /* outerClick directives */
'mobile-angular-ui.components.modals', /* modals and overlays */
'mobile-angular-ui.components.switch', /* switch form input */
'mobile-angular-ui.components.sidebars', /* sidebars */
'mobile-angular-ui.components.scrollable', /* uiScrollable directives */
'mobile-angular-ui.components.capture', /* uiYieldTo and uiContentFor directives */
'mobile-angular-ui.components.navbars' /* navbars */
]);
Die mobile-angle-ui.min.js enthält alle oben genannten Kern- und Komponentenmodule. Sie können auch die erforderlichen Komponenten gemäß Ihren Anforderungen laden, anstatt die gesamte mobile-angle-ui.min.js zu laden.
Schritt 4
Fügen Sie Ihrem Body-Tag einen Controller hinzu, wie unten gezeigt -
<body ng-app="myFirstApp" ng-controller="MainController">
Schritt 5
Im Grundlayout haben wir hinzugefügt <ng-view></ng-view>, das wird die Ansichten für uns laden.
Definieren wir die Routen in app.js mit ngRoute. Die für das Routing erforderlichen Dateien sind bereits im Kopfbereich hinzugefügt.
Erstellen Sie einen Ordner home / in src /. Fügen Sie home.html mit den folgenden Details hinzu:
<div class="list-group text-center">
<div class="list-group-item list-group-item-home">
<h1>{{msg}}</h1>
</div>
</div>
Wenn wir die App starten, möchten wir standardmäßig, dass home.html in <ng-view> </ ng-view> angezeigt wird.
Das Routing wird in app.config () wie unten gezeigt konfiguriert -
app.config(function($routeProvider, $locationProvider) {
$routeProvider
.when("/", {
templateUrl : "src/home/home.html"
});
$locationProvider.html5Mode({enabled:true, requireBase:false});
});
Schritt 6
Wir haben {{msg}} in home.html hinzugefügt, wie unten gezeigt -
<div class="list-group text-center">
<div class="list-group-item list-group-item-home">
<h1>{{msg}}</h1>
</div>
</div>
Definieren wir dasselbe in der Steuerung wie unten gezeigt -
app.controller('MainController', function($rootScope, $scope, $routeParams) {
$scope.msg="Welcome to Tutorialspoint!"
});
Schritt 7
Führen Sie nun den Befehl aus, um die App mit dem folgenden Befehl zu starten:
node server.js
Schritt 8
Laden Sie Ihre App unter http://localhost:3000 im Browser -
Im mobilen Modus wird der folgende Bildschirm angezeigt:
Im Desktop-Modus wird der folgende Bildschirm angezeigt:
Lassen Sie uns in den nächsten Kapiteln die Details der einzelnen Komponenten in der Benutzeroberfläche von Mobile Angular verstehen.
Hier ist der endgültige Code für die obige Anzeige. Die Ordnerstruktur ist bisher wie folgt:
index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Mobile Angular UI Demo</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="viewport" content="user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimal-ui" />
<meta name="apple-mobile-web-app-status-bar-style" content="yes" />
<link rel="shortcut icon" href="/assets/img/favicon.png" type="image/x-icon" />
<link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-hover.min.css" />
<link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-base.min.css" />
<link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-desktop.min.css" />
<script src="node_modules/angular/angular.min.js"></script>
<script src="node_modules/angular-route/angular-route.min.js"></script>
<script src="node_modules/mobile-angular-ui/dist/js/mobile-angular-ui.min.js"></script>
<script src="src/js/app.js"></script>
</head>
<body ng-app="myFirstApp" ng-controller="MainController">
<!-- Sidebars -->
<div class="sidebar sidebar-left"><!-- ... --></div>
<div class="sidebar sidebar-right"><!-- ... --></div>
<div class="app">
<div class="navbar navbar-app navbar-absolute-top"><!-- Top Navbar --></div>
<div class="navbar navbar-app navbar-absolute-bottom"><!-- Bottom Navbar --></div>
<!-- App body -->
<div class='app-body'>
<div class='app-content'>
<ng-view></ng-view>
</div>
</div>
</div><!-- ~ .app -->
<!-- Modals and Overlays -->
<div ui-yield-to="modals"></div>
</body>
</html>
js/app.js
/* eslint no-alert: 0 */
'use strict';
//
// Here is how to define your module
// has dependent on mobile-angular-ui
//
var app=angular.module('myFirstApp', [
'ngRoute',
'mobile-angular-ui'
]);
app.config(function($routeProvider, $locationProvider) {
$routeProvider
.when("/", {
templateUrl : "src/home/home.html"
});
$locationProvider.html5Mode({enabled:true, requireBase:false});
});
app.controller('MainController', function($rootScope, $scope, $routeParams) {
$scope.msg="Welcome to Tutorialspoint!"
});
home/home.html
<div class="list-group text-center">
<div class="list-group-item list-group-item-home">
<h1>{{msg}}</h1>
</div>
</div>