AngularJS - Pengendali

Aplikasi AngularJS terutama mengandalkan pengontrol untuk mengontrol aliran data dalam aplikasi. Kontroler didefinisikan menggunakan direktif ng-controller . Pengontrol adalah objek JavaScript yang berisi atribut / properti, dan fungsi. Setiap pengontrol menerima $ scope sebagai parameter, yang merujuk ke aplikasi / modul yang perlu ditangani pengontrol.

<div ng-app = "" ng-controller = "studentController">
   ...
</div>

Di sini, kami mendeklarasikan sebuah controller bernama studentController , menggunakan direktif ng-controller. Kami mendefinisikannya sebagai berikut -

<script>
   function studentController($scope) {
      $scope.student = {
         firstName: "Mahesh",
         lastName: "Parashar",
         
         fullName: function() {
            var studentObject;
            studentObject = $scope.student;
            return studentObject.firstName + " " + studentObject.lastName;
         }
      };
   }
</script>
  • StudentController didefinisikan sebagai objek JavaScript dengan $ scope sebagai argumen.

  • $ Scope merujuk ke aplikasi yang menggunakan objek studentController.

  • $ Scope.student adalah properti dari objek studentController.

  • FirstName dan lastName adalah dua properti objek $ scope.student. Kami memberikan nilai default kepada mereka.

  • Properti fullName adalah fungsi dari objek $ scope.student, yang mengembalikan nama gabungan.

  • Dalam fungsi fullName, kita mendapatkan objek siswa dan kemudian mengembalikan nama gabungannya.

  • Sebagai catatan, kita juga dapat mendefinisikan objek controller dalam file JS terpisah dan merujuk file tersebut di halaman HTML.

Sekarang kita dapat menggunakan properti siswa studentController menggunakan ng-model atau menggunakan ekspresi sebagai berikut -

Enter first name: <input type = "text" ng-model = "student.firstName"><br>
Enter last name: <input type = "text" ng-model = "student.lastName"><br>
<br>
You are entering: {{student.fullName()}}
  • Kami mengikat student.firstName dan student.lastname ke dua kotak input.

  • Kami mengikat student.fullName () ke HTML.

  • Sekarang setiap kali Anda mengetikkan apa pun di kotak masukan nama depan dan nama belakang, Anda dapat melihat nama lengkap diperbarui secara otomatis.

Contoh

Contoh berikut menunjukkan penggunaan pengontrol -

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Controller</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "studentController">
         Enter first name: <input type = "text" ng-model = "student.firstName"><br>
         <br>
         Enter last name: <input type = "text" ng-model = "student.lastName"><br>
         <br>
         You are entering: {{student.fullName()}}
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('studentController', function($scope) {
            $scope.student = {
               firstName: "Mahesh",
               lastName: "Parashar",
               
               fullName: function() {
                  var studentObject;
                  studentObject = $scope.student;
                  return studentObject.firstName + " " + studentObject.lastName;
               }
            };
         });
      </script>
      
   </body>
</html>

Keluaran

Buka file testAngularJS.htm di web browser dan lihat hasilnya.