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.