MEAN.JS - एंगुलर के साथ सिंगल पेज का निर्माण

MEAN स्टैक में, कोणीय को दूसरे जावास्क्रिप्ट फ्रेमवर्क के रूप में जाना जाता है, जो स्वच्छ मॉडल व्यू कंट्रोलर (MVC) तरीके से सिंगल पेज एप्लिकेशन बनाने की अनुमति देता है।

फ्रंट-एंड फ्रेमवर्क के रूप में AngularJS निम्नलिखित चीजों का उपयोग करता है -

  • फ़ाइलों और पुस्तकालयों को स्थापित करने के लिए Bower का उपयोग करता है

  • कोणीय अनुप्रयोग संरचना के लिए नियंत्रकों और सेवाओं का उपयोग करता है

  • विभिन्न HTML पेज बनाता है

  • AngularJS एप्लिकेशन के लिए रूटिंग और सेवाओं को संभालने के लिए ngRoute मॉड्यूल का उपयोग करता है

  • किसी एप्लिकेशन को आकर्षक बनाने के लिए बूटस्ट्रैप का उपयोग करता है

हमारे कोणीय आवेदन की स्थापना

आइए हम एक सरल एप्लिकेशन बनाएं जिसमें एक Node.js बैकएंड और एक AngularJS फ्रंटेंड है। हमारे कोणीय आवेदन के लिए, हम चाहेंगे -

  • दो अलग-अलग पृष्ठ (होम, छात्र)

  • प्रत्येक के लिए एक अलग कोणीय नियंत्रक

  • पृष्ठ स्विच करते समय कोई पृष्ठ ताज़ा नहीं होता है

घटकों में बोवर और पुलिंग

हमें अपने एप्लिकेशन जैसे बूटस्ट्रैप और कोणीय के लिए कुछ फाइलों की आवश्यकता होगी। हम बोवर को हमारे लिए उन घटकों को लाने के लिए कहेंगे।

सबसे पहले, अपने कमांड टर्मिनल पर नीचे कमांड को निष्पादित करने वाली अपनी मशीन पर बोवर स्थापित करें -

npm install -g bower

यह बोवर स्थापित करेगा और इसे आपके सिस्टम पर विश्व स्तर पर सुलभ बना देगा। अब फाइल को .bowerrc और bower.json को अपने रूट फोल्डर के नीचे रखें। हमारे मामले में यह हैmean-demo। दोनों फाइलों की सामग्री निम्नानुसार है -

.bowerrc - यह हमारी फ़ाइलों को रखने के लिए बोवर को बताएगा -

{
   "directory": "public/libs"
}

bower.json - यह package.json के समान है और Bower को बताएगा कि किन पैकेजों की जरूरत है।

{
   "name": "angular",
   "version": "1.0.0",
   "dependencies": {
      "bootstrap": "latest",
      "angular": "latest",
      "angular-route": "latest"
   }
}

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

$ bower install

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

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

कोणीय नियंत्रण

हमारे नियंत्रक (सार्वजनिक / js / नियंत्रकों / MainCtrl.js) इस प्रकार है -

angular.module('MainCtrl', []).controller('MainController', function($scope) {
   $scope.tagline = 'Welcome to tutorials point angular app!';
});

नियंत्रक जनता / जेएस / नियंत्रक / स्टूडेंटसक्ला.जेएस इस प्रकार है -

angular.module('StudentCtrl', []).controller('StudentController', function($scope) {
   $scope.tagline = 'Welcome to Student section!';
});

कोणीय मार्ग

हमारे रूट फ़ाइल (सार्वजनिक / js / appRoutes.js) इस प्रकार है -

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

अब जब हमारे पास हमारे नियंत्रक और मार्ग हैं, तो हम उन सभी को संयोजित करेंगे और इन मॉड्यूल को हमारे मुख्य सार्वजनिक / js / app.js में निम्नानुसार इंजेक्ट करेंगे -

angular.module('sampleApp', ['ngRoute', 'appRoutes', 'MainCtrl', 'StudentCtrl']);

फाइल देखें

कोणीय टेम्प्लेट फ़ाइल का उपयोग करता है, जिसे <div ng-view> </ div> में index.html फ़ाइल में इंजेक्ट किया जा सकता है। एनजी-व्यू निर्देश एक स्थान धारक बनाता है, जहां कॉन्फ़िगरेशन के आधार पर एक संबंधित दृश्य (HTML या एनजी-टेम्पलेट दृश्य) रखा जा सकता है। कोणीय विचारों के बारे में अधिक जानकारी के लिए, इस लिंक पर जाएँ ।

जब आप रूटिंग के साथ तैयार हों, तो छोटी टेम्प्लेट फ़ाइलें बनाएँ और उन्हें index.html फ़ाइल में इंजेक्ट करें । 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/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>

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

क्रियान्वयन

आप इस लिंक में इस एप्लिकेशन के लिए स्रोत कोड डाउनलोड कर सकते हैं । ज़िप फ़ाइल डाउनलोड करें; इसे अपने सिस्टम में निकालें। टर्मिनल खोलें और npm मॉड्यूल निर्भरता स्थापित करने के लिए नीचे कमांड चलाएं।

$ cd mean-demo
$ npm install

अगला कमांड नीचे चलाएं -

$ node start

जैसा कि नीचे दी गई छवि में दिखाया गया है, आपको एक पुष्टि मिलेगी -

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

छात्र लिंक पर क्लिक करें , आपको नीचे स्क्रीन दिखाई देगी -

हमारा Angular frontend टेम्प्लेट फ़ाइल का उपयोग करेगा और हमारी index.html फ़ाइल में <div ng-view> </ div> में इंजेक्ट करेगा । यह बिना पेज रिफ्रेश के ऐसा करेगा।