MEAN.JS - एक एसपीए का निर्माण: अगला स्तर

पिछले अध्याय में, हमने एंगुलरज का उपयोग करते हुए सिंगल पेज मीनज एप्लिकेशन का निर्माण देखा है। इस अध्याय में, आइए देखें कि मोंगोडब से डेटा प्राप्त करने के लिए कोणीय एप्लिकेशन एपीआई का उपयोग कैसे करता है।

आप इस लिंक में इस एप्लिकेशन के लिए स्रोत कोड डाउनलोड कर सकते हैं । ज़िप फ़ाइल डाउनलोड करें; इसे अपने सिस्टम में निकालें।

हमारे स्रोत कोड की निर्देशिका संरचना इस प्रकार है -

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

इस एप्लिकेशन में, हमने एक दृश्य (home.html) बनाया है, जो संग्रह छात्र से सभी छात्रों को सूचीबद्ध करेगा, हमें एक नया बनाने की अनुमति देता है studentरिकॉर्ड करें और हमें छात्र रिकॉर्ड को हटाने की अनुमति दें। ये सभी ऑपरेशन REST API कॉल के माध्यम से किए जाते हैं।

टर्मिनल खोलें और npm मॉड्यूल निर्भरता स्थापित करने के लिए नीचे कमांड चलाएं।

$ npm install

अगला, नीचे कमांड का उपयोग करके बोवर घटकों को स्थापित करें। आप सार्वजनिक / परिवादों के तहत सभी फाइलों में बोअर पुल देख सकते हैं।

$ bower install

किसी अनुप्रयोग के लिए नोड कॉन्फ़िगरेशन सर्वर में सहेजा जाएगा। जेएस फ़ाइल। यह नोड एप की मुख्य फाइल है और पूरे एप्लिकेशन को कॉन्फ़िगर करेगी।

// 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}!`));

सीमावर्ती मार्ग को परिभाषित करना

सार्वजनिक / index.html फ़ाइल कोड स्निपेट निम्नलिखित होगा -

<!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>

हमने एपीआई कॉल करने और एपीआई अनुरोधों को निष्पादित करने के लिए एक सेवा लिखी है। हमारी सेवा, छात्र सेवा नीचे दी गई है -

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);
      }
   }
}]);

हमारा नियंत्रक (MainCtrl.js) कोड निम्नानुसार है -

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
      });
   };
}]);

रनिंग एप्लीकेशन

अपनी परियोजना निर्देशिका पर नेविगेट करें और नीचे दिए गए कमांड को चलाएं -

$ npm start

अब नेविगेट करें http://localhost:3000 और आपको नीचे चित्र में दिखाए अनुसार पृष्ठ मिलेगा -

टेक्स्ट बॉक्स में कुछ टेक्स्ट डालें और क्लिक करें Addबटन। एक रिकॉर्ड जोड़ा जाता है और निम्नानुसार प्रदर्शित किया जाता है -

आप चेक बॉक्स को चेक करके रिकॉर्ड हटा सकते हैं।