MEAN.JS - Erstellen einer einzelnen Seite mit Angular
Im MEAN-Stack wird Angular als zweites JavaScript-Framework bezeichnet, mit dem einzelne Seitenanwendungen auf saubere Weise mit Model View Controller (MVC) erstellt werden können.
AngularJS als Front-End-Framework verwendet folgende Dinge:
Verwendet Bower zum Installieren von Dateien und Bibliotheken
Verwendet Controller und Dienste für die Angular-Anwendungsstruktur
Erstellt verschiedene HTML-Seiten
Verwendet das ngRoute- Modul, um Routing und Dienste für AngularJS-Anwendungen zu verwalten
Verwendet Bootstrap, um eine Anwendung attraktiv zu machen
Einrichten unserer Winkelanwendung
Lassen Sie uns eine einfache Anwendung erstellen, die ein Node.js-Backend und ein AngularJS-Frontend hat. Für unsere Angular-Anwendung wollen wir -
Zwei verschiedene Seiten (Home, Student)
Jeweils ein anderer Winkelregler
Keine Seitenaktualisierung beim Seitenwechsel
Laube und Einziehen von Bauteilen
Wir benötigen bestimmte Dateien für unsere Anwendung wie Bootstrap und Angular. Wir werden bower anweisen, diese Komponenten für uns zu holen.
Installieren Sie zuerst die Laube auf Ihrem Computer, indem Sie den folgenden Befehl auf Ihrem Befehlsterminal ausführen.
npm install -g bower
Dadurch wird Bower installiert und auf Ihrem System global verfügbar gemacht. Legen Sie nun die Dateien .bowerrc und bower.json unter Ihrem Stammordner ab. In unserem Fall ist esmean-demo. Der Inhalt beider Dateien ist wie folgt:
.bowerrc - Dadurch wird Bower mitgeteilt, wo unsere Dateien abgelegt werden sollen.
{
"directory": "public/libs"
}
bower.json - Dies ähnelt package.json und teilt Bower mit, welche Pakete benötigt werden.
{
"name": "angular",
"version": "1.0.0",
"dependencies": {
"bootstrap": "latest",
"angular": "latest",
"angular-route": "latest"
}
}
Installieren Sie als Nächstes die Bower-Komponenten mit dem folgenden Befehl. Sie können sehen, wie Bower alle Dateien unter public / libs abruft .
$ bower install
Unsere Verzeichnisstruktur wäre wie folgt:
mean-demo
-app
-config
-node_modules
-public
-js
--controllers
-MainCtrl.js
-StudentCtrl.js
--app.js
--appRoutes.js
-libs
-views
--home.html
--student.html
-index.html
-bower.json
-package.json
-server.js
Winkelregler
Unser Controller (public / js / controller / MainCtrl.js) lautet wie folgt:
angular.module('MainCtrl', []).controller('MainController', function($scope) {
$scope.tagline = 'Welcome to tutorials point angular app!';
});
Controller public / js / controller / StudentCtrl.js lautet wie folgt:
angular.module('StudentCtrl', []).controller('StudentController', function($scope) {
$scope.tagline = 'Welcome to Student section!';
});
Winkelrouten
Unsere Routendatei (public / js / appRoutes.js) lautet wie folgt:
angular.module('appRoutes', []).config(['$routeProvider',
'$locationProvider', function($routeProvider, $locationProvider) {
$routeProvider
// home page
.when('/', {
templateUrl: 'views/home.html',
controller: 'MainController'
})
// students page that will use the StudentController
.when('/students', {
templateUrl: 'views/student.html',
controller: 'StudentController'
});
$locationProvider.html5Mode(true);
}]);
Nachdem wir unsere Controller und Routen haben, werden wir sie alle kombinieren und diese Module wie folgt in unsere Hauptöffentlichkeit / js / app.js einfügen -
angular.module('sampleApp', ['ngRoute', 'appRoutes', 'MainCtrl', 'StudentCtrl']);
Datei ansehen
Angular verwendet die Vorlagendatei, die in die Datei <div ng-view> </ div> in der Datei index.html eingefügt werden kann. Die Direktive ng-view erstellt einen Platzhalter, in dem eine entsprechende Ansicht (HTML- oder ng-Template-Ansicht) basierend auf der Konfiguration platziert werden kann. Weitere Informationen zu Winkelansichten finden Sie unter diesem Link .
Wenn Sie mit dem Routing fertig sind, erstellen Sie kleinere Vorlagendateien und fügen Sie sie in die Datei index.html ein . Die Datei index.html enthält den folgenden Codeausschnitt:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<base href="/">
<title>Tutorialspoint Node and Angular</title>
<!-- CSS -->
<link rel="stylesheet" href="libs/bootstrap/dist/css/bootstrap.min.css">
<link rel="stylesheet" href="css/style.css"> <!-- custom styles -->
<!-- JS -->
<script src="libs/angular/angular.min.js"></script>
<script src="libs/angular-route/angular-route.min.js"></script>
<!-- ANGULAR CUSTOM -->
<script src="js/controllers/MainCtrl.js"></script>
<script src="js/controllers/StudentCtrl.js"></script>
<script src="js/appRoutes.js"></script>
<script src="js/app.js"></script>
</head>
<body ng-app="sampleApp" ng-controller="MainController">
<div class="container">
<!-- HEADER -->
<nav class="navbar navbar-inverse">
<div class="navbar-header">
<a class="navbar-brand" href="/">Tutorial</a>
</div>
<ul class="nav navbar-nav">
<li><a href="/students">Students</a></li>
</ul>
</nav>
<!-- ANGULAR DYNAMIC CONTENT -->
<div ng-view></div>
</div>
</body>
</html>
Anwendung ausführen
Ausführung
Sie können den Quellcode für diese Anwendung unter diesem Link herunterladen . Laden Sie die Zip-Datei herunter. Extrahieren Sie es in Ihrem System. Öffnen Sie das Terminal und führen Sie den folgenden Befehl aus, um die Abhängigkeiten des npm-Moduls zu installieren.
$ cd mean-demo
$ npm install
Führen Sie als nächstes den folgenden Befehl aus -
$ node start
Sie erhalten eine Bestätigung wie im Bild unten gezeigt -
Gehen Sie nun zum Browser und geben Sie ein http://localhost:3000. Sie erhalten die Seite wie im Bild unten gezeigt -
Klicken Sie auf den Link Studenten. Der folgende Bildschirm wird angezeigt:
Unser Angular-Frontend verwendet die Vorlagendatei und fügt sie in die <div ng-view> </ div> in unserer index.html- Datei ein. Dies geschieht ohne Seitenaktualisierung.