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.