MEAN.JS - Aufbau eines SPA: Das nächste Level

Im vorherigen Kapitel haben wir die Erstellung einer Single-Page-Meanjs-Anwendung mit Angularjs gesehen. In diesem Kapitel sehen wir uns an, wie die Angular-Anwendung die API verwendet, um die Daten von Mongodb abzurufen.

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.

Die Verzeichnisstruktur unseres Quellcodes lautet wie folgt:

mean-demo
   -app
      -models
         -student.js
   -config
      -db.js
   -public
      -js
         -controllers
            -MainCtrl.js
            -StudentCtrl.js
         -services
            -StudentService.js
         -app.js
         -appRoutes.js
      -views
         -home.html
         -student.html
      -index.html
   -.bowerrc
   -bower.json
   -package.json
   -server.js

In dieser Anwendung haben wir eine Ansicht (home.html) erstellt, in der alle Schüler aus der Sammlung Student aufgelistet sind, damit wir eine neue erstellen können studentNehmen Sie auf und erlauben Sie uns, den Schülerdatensatz zu löschen. Alle diese Vorgänge werden über REST-API-Aufrufe ausgeführt.

Öffnen Sie das Terminal und führen Sie den folgenden Befehl aus, um die Abhängigkeiten des npm-Moduls zu installieren.

$ npm install

Installieren Sie anschließend die Bower-Komponenten mit dem folgenden Befehl. Sie können Bower Pull in allen Dateien unter public / libs sehen.

$ bower install

Die Knotenkonfiguration für eine Anwendung wird in der Datei server.js gespeichert. Dies ist die Hauptdatei der Knoten-App und konfiguriert die gesamte Anwendung.

// modules =================================================
const express = require('express');
const app = express();
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var methodOverride = require('method-override');
// set our port
const port = 3000;
// configuration ===========================================
// configure body parser
app.use(bodyParser.json()); // parse application/json

// parse application/vnd.api+json as json
app.use(bodyParser.json({ type: 'application/vnd.api+json' }));

// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: true }));

// override with the X-HTTP-Method-Override header in the request.
app.use(methodOverride('X-HTTP-Method-Override')); simulate DELETE/PUT

// set the static files location /public/img will be /img for users
app.use(express.static(__dirname + '/public'));

// config files
var db = require('./config/db');
console.log("connecting--",db);
mongoose.connect(db.url); //Mongoose connection created

// grab the student model
var Student = require('./app/models/student');
function getStudents(res) {
   Student.find(function (err, students) {
      // if there is an error retrieving, send the error. nothing after res.send(err) will execute
         if (err) {
            res.send(err);
         }
         res.json(students); // return all todos in JSON format
      });
   };
app.get('/api/studentslist', function(req, res) {
   getStudents(res);
});
app.post('/api/students/send', function (req, res) {
   var student = new Student(); // create a new instance of the student model
   student.name = req.body.name; // set the student name (comes from the request)
   student.save(function(err) {
      if (err)
         res.send(err);
         getStudents(res);
   });
});
app.delete('/api/students/:student_id', function (req, res) {
   Student.remove({
      _id: req.params.student_id
      }, function(err, bear) {
         if (err)
            res.send(err);
         getStudents(res);
      });
});
// startup our app at http://localhost:3000
app.listen(port, () ⇒ console.log(`Example app listening on port ${port}!`));

Frontend-Route definieren

Die Datei public / 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/services/StudentService.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>

Wir haben einen Service geschrieben, um die API-Aufrufe durchzuführen und die API-Anforderungen auszuführen. Unser Service, StudentService, sieht wie folgt aus:

angular.module('StudentService', [])
// super simple service
// each function returns a promise object
.factory('Student', ['$http',function($http) {
   return {
      get : function() {
         return $http.get('/api/students');
      },
      create : function(student) {
         return $http.post('/api/students/send', student);
      },
      delete : function(id) {
         return $http.delete('/api/students/' + id);
      }
   }
}]);

Unser Controller-Code (MainCtrl.js) lautet wie folgt:

angular.module('MainCtrl', []).controller('MainController',
   ['$scope','$http','Student',function($scope, $http, Student) {
   $scope.formData = {};
   $scope.loading = true;
   $http.get('/api/studentslist').
   then(function(response) {
      $scope.student = response.data;
   });
   // CREATE 
   // when submitting the add form, send the text to the node API
   $scope.createStudent = function() {
      // validate the formData to make sure that something is there
      // if form is empty, nothing will happen
      if ($scope.formData.name != undefined) {
         $scope.loading = true;
         // call the create function from our service (returns a promise object)
         Student.create($scope.formData)
         // if successful creation, call our get function to get all the new Student
         .then(function (response){
            $scope.student = response.data;
            $scope.loading = false;
            $scope.formData = {}
         },    function (error){
         });
      }
   };
   // DELETE
   ==================================================================
   // delete a todo after checking it
   $scope.deleteStudent = function(id) {
      $scope.loading = true;
      Student.delete(id)
      // if successful delete, call our get function to get all the new Student
      .then(function(response) {
         $scope.loading = false;
         new list of Student
      });
   };
}]);

Anwendung ausführen

Navigieren Sie zu Ihrem Projektverzeichnis und führen Sie den folgenden Befehl aus:

$ npm start

Navigieren Sie nun zu http://localhost:3000 und Sie erhalten die Seite wie im Bild unten gezeigt -

Geben Sie einen Text in das Textfeld ein und klicken Sie auf AddTaste. Ein Datensatz wird wie folgt hinzugefügt und angezeigt:

Sie können den Datensatz löschen, indem Sie das Kontrollkästchen aktivieren.