AngularJS - Panduan Cepat
Apa itu AngularJS?
AngularJS adalah kerangka aplikasi web open source. Ini awalnya dikembangkan pada tahun 2009 oleh Misko Hevery dan Adam Abrons. Sekarang dikelola oleh Google. Versi terbarunya adalah 1.4.3.
Definisi AngularJS menurut dokumentasi resminya adalah sebagai berikut -
AngularJS adalah kerangka kerja struktural untuk aplikasi web dinamis. Ini memungkinkan Anda menggunakan HTML sebagai bahasa template Anda dan memungkinkan Anda memperluas sintaks HTML untuk mengekspresikan komponen aplikasi Anda dengan jelas dan ringkas. Data binding dan injeksi dependensi Angular menghilangkan banyak kode yang saat ini harus Anda tulis. Dan itu semua terjadi di dalam browser, menjadikannya mitra yang ideal dengan teknologi server apa pun.
fitur
AngularJS adalah kerangka kerja pengembangan berbasis JavaScript yang kuat untuk membuat RICH Internet Application (RIA).
AngularJS menyediakan opsi pengembang untuk menulis aplikasi sisi klien (menggunakan JavaScript) dengan cara MVC (Model View Controller) yang bersih.
Aplikasi yang ditulis dalam AngularJS kompatibel dengan lintas browser. AngularJS secara otomatis menangani kode JavaScript yang cocok untuk setiap browser.
AngularJS adalah open source, sepenuhnya gratis, dan digunakan oleh ribuan pengembang di seluruh dunia. Ini dilisensikan di bawah Lisensi Apache versi 2.0.
Secara keseluruhan, AngularJS adalah kerangka kerja untuk membangun aplikasi web berskala besar dan berkinerja tinggi sekaligus menjaganya agar tetap mudah dipelihara.
Fitur Inti
Berikut adalah fitur inti terpenting dari AngularJS -
Data-binding - Ini adalah sinkronisasi otomatis data antara model dan komponen tampilan.
Scope- Ini adalah objek yang mengacu pada model. Mereka bertindak sebagai perekat antara pengontrol dan tampilan.
Controller - Ini adalah fungsi JavaScript yang terikat pada cakupan tertentu.
Services- AngularJS hadir dengan beberapa layanan bawaan misalnya $ https: untuk membuat XMLHttpRequests. Ini adalah objek tunggal yang dibuat instance-nya hanya sekali dalam aplikasi.
Filters - Ini memilih subset item dari array dan mengembalikan array baru.
Directives- Direktif adalah penanda pada elemen DOM (seperti elemen, atribut, css, dan lainnya). Ini dapat digunakan untuk membuat tag HTML khusus yang berfungsi sebagai widget khusus baru. AngularJS memiliki arahan bawaan (ngBind, ngModel ...)
Templates- Ini adalah tampilan yang diberikan dengan informasi dari pengontrol dan model. Ini bisa berupa file tunggal (seperti index.html) atau beberapa tampilan dalam satu halaman menggunakan "sebagian".
Routing - Ini adalah konsep bertukar pandangan.
Model View Whatever- MVC adalah pola desain untuk membagi aplikasi menjadi beberapa bagian (disebut Model, View, dan Controller), masing-masing dengan tanggung jawab yang berbeda. AngularJS tidak mengimplementasikan MVC dalam pengertian tradisional, melainkan sesuatu yang lebih dekat dengan MVVM (Model-View-ViewModel). Tim Angular JS menyebutnya sebagai Model View Apapun.
Deep Linking- Tautan dalam memungkinkan Anda untuk menyandikan status aplikasi di URL sehingga dapat di-bookmark. Aplikasi kemudian dapat dikembalikan dari URL ke status yang sama.
Dependency Injection - AngularJS memiliki subsistem injeksi ketergantungan bawaan yang membantu pengembang dengan membuat aplikasi lebih mudah untuk dikembangkan, dipahami, dan diuji.
Konsep
Diagram berikut menggambarkan beberapa bagian penting dari AngularJS yang akan kita bahas secara rinci pada bab-bab selanjutnya.
Keuntungan dari AngularJS
AngularJS memberikan kemampuan untuk membuat Aplikasi Halaman Tunggal dengan cara yang sangat bersih dan dapat dipelihara.
AngularJS menyediakan kemampuan pengikatan data ke HTML sehingga memberi pengguna pengalaman yang kaya dan responsif
Kode AngularJS dapat diuji unit.
AngularJS menggunakan injeksi ketergantungan dan memanfaatkan pemisahan masalah.
AngularJS menyediakan komponen yang dapat digunakan kembali.
Dengan AngularJS, pengembang menulis lebih sedikit kode dan mendapatkan lebih banyak fungsionalitas.
Di AngularJS, tampilan adalah halaman html murni, dan pengontrol yang ditulis dalam JavaScript melakukan pemrosesan bisnis.
Di atas segalanya, aplikasi AngularJS dapat berjalan di semua browser utama dan ponsel pintar termasuk ponsel / tablet berbasis Android dan iOS.
Kerugian dari AngularJS
Meskipun AngularJS hadir dengan banyak poin plus tetapi pada saat yang sama kita harus mempertimbangkan poin-poin berikut -
Not Secure- Karena hanya framework JavaScript, aplikasi yang ditulis dalam AngularJS tidak aman. Autentikasi dan otorisasi sisi server diperlukan untuk menjaga keamanan aplikasi.
Not degradable - Jika pengguna aplikasi Anda menonaktifkan JavaScript maka pengguna hanya akan melihat halaman dasar dan tidak lebih.
Komponen AngularJS
Kerangka AngularJS dapat dibagi menjadi tiga bagian utama berikut -
ng-app - Direktif ini mendefinisikan dan menautkan aplikasi AngularJS ke HTML.
ng-model - Direktif ini mengikat nilai data aplikasi AngularJS ke kontrol input HTML.
ng-bind - Direktif ini mengikat data Aplikasi AngularJS ke tag HTML.
Pada bab ini kita akan membahas tentang bagaimana mengatur library AngularJS untuk digunakan dalam pengembangan aplikasi web. Kami juga akan mempelajari secara singkat struktur direktori dan isinya.
Saat Anda membuka tautan https://angularjs.org/, Anda akan melihat ada dua opsi untuk mengunduh pustaka AngularJS -
View on GitHub - Klik tombol ini untuk membuka GitHub dan mendapatkan semua skrip terbaru.
Download AngularJS 1 - Atau klik tombol ini, layar seperti di bawah ini akan terlihat -
Layar ini memberikan berbagai pilihan untuk menggunakan Angular JS sebagai berikut -
Downloading and hosting files locally
Ada dua opsi berbeda legacy dan latest. Nama itu sendiri deskriptif.legacy memiliki versi kurang dari 1.2.x dan latest memiliki versi 1.5.x.
Kami juga dapat menggunakan versi yang diperkecil, tidak dikompresi atau di-zip.
CDN access- Anda juga memiliki akses ke CDN. CDN akan memberi Anda akses di seluruh dunia ke pusat data regional yang dalam hal ini, host Google. Ini berarti menggunakan CDN memindahkan tanggung jawab hosting file dari server Anda sendiri ke serangkaian server eksternal. Ini juga menawarkan keuntungan bahwa jika pengunjung laman web Anda telah mengunduh salinan AngularJS dari CDN yang sama, itu tidak perlu diunduh ulang.
Try the new angularJS 2 - Klik tombol ini untuk mengunduh Angular JS versi beta 2. Versi ini sangat cepat, mendukung seluler, dan fleksibel dibandingkan dengan AngularJS 1 yang lama dan terbaru
Kami menggunakan versi CDN pustaka sepanjang tutorial ini.
Contoh
Sekarang mari kita tulis contoh sederhana menggunakan library AngularJS. Mari kita buat file HTML myfirstexample.html seperti di bawah ini -
<!doctype html>
<html>
<head>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.5.2/angular.min.js"></script>
</head>
<body ng-app = "myapp">
<div ng-controller = "HelloController" >
<h2>Welcome {{helloTo.title}} to the world of Tutorialspoint!</h2>
</div>
<script>
angular.module("myapp", [])
.controller("HelloController", function($scope) {
$scope.helloTo = {};
$scope.helloTo.title = "AngularJS";
});
</script>
</body>
</html>
Bagian berikut menjelaskan kode di atas secara rinci -
Sertakan AngularJS
Kami telah menyertakan file JavaScript AngularJS di halaman HTML sehingga kami dapat menggunakan AngularJS -
<head>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
</head>
Jika Anda ingin memperbarui Angular JS ke versi terbaru, gunakan sumber skrip berikut atau Periksa versi terbaru AngularJS di situs web resmi mereka.
<head>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.5.2/angular.min.js"></script>
</head>
Arahkan ke aplikasi AngularJS
Selanjutnya kami memberi tahu bagian mana dari HTML yang berisi aplikasi AngularJS. Ini dilakukan dengan menambahkan atribut ng-app ke elemen HTML root aplikasi AngularJS. Anda dapat menambahkannya ke elemen html atau elemen tubuh seperti yang ditunjukkan di bawah ini -
<body ng-app = "myapp">
</body>
Melihat
Pemandangan adalah bagian ini -
<div ng-controller = "HelloController" >
<h2>Welcome {{helloTo.title}} to the world of Tutorialspoint!</h2>
</div>
ng-controller memberitahu AngularJS controller apa yang akan digunakan dengan view ini. helloTo.title memberi tahu AngularJS untuk menulis nilai "model" bernama helloTo.title ke HTML di lokasi ini.
Kontroler
Bagian pengontrol adalah -
<script>
angular.module("myapp", [])
.controller("HelloController", function($scope) {
$scope.helloTo = {};
$scope.helloTo.title = "AngularJS";
});
</script>
Kode ini mendaftarkan fungsi pengontrol bernama HelloController di modul sudut bernama myapp . Kami akan mempelajari lebih lanjut tentang modul dan pengontrol di bab masing-masing. Fungsi pengontrol didaftarkan dalam sudut melalui pemanggilan fungsi angular.module (...). Controller (...).
Parameter $ scope yang dikirimkan ke fungsi controller adalah model . Fungsi controller menambahkan objek JavaScript helloTo , dan di objek itu menambahkan field judul .
Eksekusi
Simpan kode di atas sebagai myfirstexample.html dan buka di browser apa pun. Anda akan melihat output seperti di bawah ini -
Welcome AngularJS to the world of Tutorialspoint!
Saat halaman dimuat di browser, hal-hal berikut terjadi -
Dokumen HTML dimuat ke browser, dan dievaluasi oleh browser. File JavaScript AngularJS dimuat, objek global sudut dibuat. Selanjutnya, JavaScript yang mendaftarkan fungsi pengontrol dijalankan.
AngularJS berikutnya memindai HTML untuk mencari aplikasi dan tampilan AngularJS. Setelah tampilan ditemukan, ini menghubungkan tampilan tersebut ke fungsi pengontrol yang sesuai.
Selanjutnya, AngularJS menjalankan fungsi pengontrol. Ini kemudian merender tampilan dengan data dari model yang diisi oleh pengontrol. Halamannya sekarang sudah siap.
Model View Controller atau MVC seperti yang biasa disebut, adalah pola desain perangkat lunak untuk mengembangkan aplikasi web. Pola Model View Controller terdiri dari tiga bagian berikut -
Model - Ini adalah level terendah dari pola yang bertanggung jawab untuk memelihara data.
View - Bertanggung jawab untuk menampilkan semua atau sebagian data kepada pengguna.
Controller - Ini adalah Kode perangkat lunak yang mengontrol interaksi antara Model dan Tampilan.
MVC populer karena mengisolasi logika aplikasi dari lapisan antarmuka pengguna dan mendukung pemisahan perhatian. Pengontrol menerima semua permintaan untuk aplikasi dan kemudian bekerja dengan model untuk menyiapkan data apa pun yang diperlukan oleh tampilan. Tampilan kemudian menggunakan data yang disiapkan oleh pengontrol untuk menghasilkan respons akhir yang dapat disajikan. Abstraksi MVC dapat direpresentasikan secara grafis sebagai berikut.
Model
Model bertanggung jawab untuk mengelola data aplikasi. Ini menanggapi permintaan dari tampilan dan instruksi dari pengontrol untuk memperbarui dirinya sendiri.
Pandangan
Penyajian data dalam format tertentu, dipicu oleh keputusan pengontrol untuk menyajikan data. Mereka adalah sistem template berbasis skrip seperti JSP, ASP, PHP dan sangat mudah diintegrasikan dengan teknologi AJAX.
Pengendali
Pengontrol menanggapi masukan pengguna dan melakukan interaksi pada objek model data. Pengontrol menerima input, memvalidasinya, dan kemudian melakukan operasi bisnis yang mengubah status model data.
AngularJS adalah kerangka kerja berbasis MVC. Dalam bab-bab selanjutnya, kita akan melihat bagaimana AngularJS menggunakan metodologi MVC.
Sebelum kita mulai dengan membuat aplikasi HelloWorld yang sebenarnya menggunakan AngularJS, mari kita lihat apa saja bagian sebenarnya dari aplikasi AngularJS. Aplikasi AngularJS terdiri dari tiga bagian penting berikut -
ng-app - Direktif ini mendefinisikan dan menautkan aplikasi AngularJS ke HTML.
ng-model - Direktif ini mengikat nilai data aplikasi AngularJS ke kontrol input HTML.
ng-bind - Direktif ini mengikat data Aplikasi AngularJS ke tag HTML.
Langkah-langkah membuat Aplikasi AngularJS
Langkah 1: Muat kerangka kerja
Menjadi kerangka kerja JavaScript murni, itu dapat ditambahkan menggunakan tag <Script>.
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
Langkah 2: Tentukan Aplikasi AngularJS menggunakan direktif ng-app
<div ng-app = "">
...
</div>
Langkah 3: Tentukan nama model menggunakan direktif ng-model
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
Langkah 4: Bind nilai model di atas yang ditentukan menggunakan direktif ng-bind.
<p>Hello <span ng-bind = "name"></span>!</p>
Langkah-langkah untuk menjalankan Aplikasi AngularJS
Gunakan tiga langkah yang disebutkan di atas dalam halaman HTML.
testAngularJS.htm
<html>
<head>
<title>AngularJS First Application</title>
</head>
<body>
<h1>Sample Application</h1>
<div ng-app = "">
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<p>Hello <span ng-bind = "name"></span>!</p>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Masukkan nama Anda dan lihat hasilnya.
Bagaimana AngularJS terintegrasi dengan HTML
Direktif ng-app menunjukkan dimulainya aplikasi AngularJS.
direktif ng-model kemudian membuat variabel model bernama "name" yang dapat digunakan dengan halaman html dan di dalam div yang memiliki direktif ng-app.
ng-bind kemudian menggunakan model nama untuk ditampilkan di tag span html setiap kali pengguna memasukkan sesuatu ke dalam kotak teks.
Tag penutup </div> menunjukkan akhir dari aplikasi AngularJS.
Direktif AngularJS digunakan untuk memperluas HTML. Ini adalah atribut khusus yang dimulai dengan awalan ng-. Kami akan membahas arahan berikut -
ng-app - Direktif ini memulai Aplikasi AngularJS.
ng-init - Direktif ini menginisialisasi data aplikasi.
ng-model - Direktif ini mengikat nilai data aplikasi AngularJS ke kontrol input HTML.
ng-repeat - Direktif ini mengulangi elemen html untuk setiap item dalam koleksi.
direktif ng-app
direktif ng-app memulai Aplikasi AngularJS. Ini mendefinisikan elemen root. Secara otomatis menginisialisasi atau mem-bootstrap aplikasi ketika halaman web yang berisi Aplikasi AngularJS dimuat. Ini juga digunakan untuk memuat berbagai modul AngularJS di Aplikasi AngularJS. Dalam contoh berikut, kami telah mendefinisikan aplikasi AngularJS default menggunakan atribut ng-app dari elemen div.
<div ng-app = "">
...
</div>
direktif ng-init
direktif ng-init menginisialisasi data Aplikasi AngularJS. Ini digunakan untuk memberi nilai pada variabel yang akan digunakan dalam aplikasi. Dalam contoh berikut, kami akan menginisialisasi berbagai negara. Kami menggunakan sintaks JSON untuk menentukan berbagai negara.
<div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United States'},
{locale:'en-GB',name:'United Kingdom'}, {locale:'en-FR',name:'France'}]">
...
</div>
direktif ng-model
Direktif ini mengikat nilai data aplikasi AngularJS ke kontrol input HTML. Dalam contoh berikut, kami telah menetapkan model bernama "nama".
<div ng-app = "">
...
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
</div>
ng-repeat direktif
direktif ng-repeat mengulangi elemen html untuk setiap item dalam sebuah koleksi. Dalam contoh berikut, kami telah mengulangi berbagai negara.
<div ng-app = "">
...
<p>List of Countries with locale:</p>
<ol>
<li ng-repeat = "country in countries">
{{ 'Country: ' + country.name + ', Locale: ' + country.locale }}
</li>
</ol>
</div>
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>AngularJS Directives</title>
</head>
<body>
<h1>Sample Application</h1>
<div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United States'},
{locale:'en-GB',name:'United Kingdom'}, {locale:'en-FR',name:'France'}]">
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<p>Hello <span ng-bind = "name"></span>!</p>
<p>List of Countries with locale:</p>
<ol>
<li ng-repeat = "country in countries">
{{ 'Country: ' + country.name + ', Locale: ' + country.locale }}
</li>
</ol>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Masukkan nama Anda dan lihat hasilnya.
Ekspresi digunakan untuk mengikat data aplikasi ke html. Ekspresi ditulis di dalam tanda kurung kurawal seperti {{ekspresi}}. Ekspresi berperilaku dengan cara yang sama seperti perintah ng-bind. Ekspresi aplikasi AngularJS adalah ekspresi javascript murni dan mengeluarkan data tempat mereka digunakan.
Menggunakan angka
<p>Expense on Books : {{cost * quantity}} Rs</p>
Menggunakan string
<p>Hello {{student.firstname + " " + student.lastname}}!</p>
Menggunakan objek
<p>Roll No: {{student.rollno}}</p>
Menggunakan array
<p>Marks(Math): {{marks[3]}}</p>
Contoh
Contoh berikut akan menampilkan semua ekspresi yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>AngularJS Expressions</title>
</head>
<body>
<h1>Sample Application</h1>
<div ng-app = "" ng-init = "quantity = 1;cost = 30;
student = {firstname:'Mahesh',lastname:'Parashar',rollno:101};
marks = [80,90,75,73,60]">
<p>Hello {{student.firstname + " " + student.lastname}}!</p>
<p>Expense on Books : {{cost * quantity}} Rs</p>
<p>Roll No: {{student.rollno}}</p>
<p>Marks(Math): {{marks[3]}}</p>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
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 dikontrol oleh pengontrol.
<div ng-app = "" ng-controller = "studentController">
...
</div>
Di sini kami telah menyatakan pengontrol studentControllermenggunakan direktif ng-controller. Sebagai langkah selanjutnya kita akan mendefinisikan studentController 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 telah memberikan nilai default kepada mereka.
fullName adalah fungsi dari objek $ scope.student yang tugasnya adalah mengembalikan nama gabungan.
Dalam fungsi fullName kita mendapatkan objek siswa dan kemudian mengembalikan nama gabungannya.
Sebagai catatan, kita juga bisa mendefinisikan objek controller di file JS terpisah dan merujuk file itu 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 telah membatasi student.firstName dan student.lastname ke dua kotak masukan.
Kami telah membatasi 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 akan menampilkan 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 textAngularJS.htm di browser web. Lihat hasilnya.
Filter digunakan untuk mengubah mengubah data dan dapat dipukul dalam ekspresi atau arahan menggunakan karakter pipa. Berikut adalah daftar filter yang biasa digunakan.
Sr.No. | Nama & Deskripsi |
---|---|
1 | uppercase mengonversi teks menjadi teks huruf besar. |
2 | lowercase mengonversi teks menjadi teks huruf kecil. |
3 | currency memformat teks dalam format mata uang. |
4 | filter memfilter larik menjadi bagiannya berdasarkan kriteria yang diberikan. |
5 | orderby memesan array berdasarkan kriteria yang diberikan. |
filter huruf besar
Tambahkan filter huruf besar ke ekspresi menggunakan karakter pipa. Di sini kami telah menambahkan filter huruf besar untuk mencetak nama siswa dengan huruf kapital semua.
Enter first name:<input type = "text" ng-model = "student.firstName">
Enter last name: <input type = "text" ng-model = "student.lastName">
Name in Upper Case: {{student.fullName() | uppercase}}
filter huruf kecil
Tambahkan filter huruf kecil ke ekspresi menggunakan karakter pipa. Di sini kami telah menambahkan filter huruf kecil untuk mencetak nama siswa dalam semua huruf kecil.
Enter first name:<input type = "text" ng-model = "student.firstName">
Enter last name: <input type = "text" ng-model = "student.lastName">
Name in Lower Case: {{student.fullName() | lowercase}}
filter mata uang
Tambahkan filter mata uang ke nomor yang mengembalikan ekspresi menggunakan karakter pipa. Di sini kami telah menambahkan filter mata uang untuk mencetak biaya menggunakan format mata uang.
Enter fees: <input type = "text" ng-model = "student.fees">
fees: {{student.fees | currency}}
filter filter
Untuk menampilkan hanya subjek yang diperlukan, kami telah menggunakan subjectName sebagai filter.
Enter subject: <input type = "text" ng-model = "subjectName">
Subject:
<ul>
<li ng-repeat = "subject in student.subjects | filter: subjectName">
{{ subject.name + ', marks:' + subject.marks }}
</li>
</ul>
orderby filter
Untuk mengurutkan subjek berdasarkan tanda, kami telah menggunakan tanda orderBy.
Subject:
<ul>
<li ng-repeat = "subject in student.subjects | orderBy:'marks'">
{{ subject.name + ', marks:' + subject.marks }}
</li>
</ul>
Contoh
Contoh berikut akan menampilkan semua filter yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Filters</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">
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input type = "text" ng-model = "student.firstName"></td>
</tr>
<tr>
<td>Enter last name: </td>
<td><input type = "text" ng-model = "student.lastName"></td>
</tr>
<tr>
<td>Enter fees: </td>
<td><input type = "text" ng-model = "student.fees"></td>
</tr>
<tr>
<td>Enter subject: </td>
<td><input type = "text" ng-model = "subjectName"></td>
</tr>
</table>
<br/>
<table border = "0">
<tr>
<td>Name in Upper Case: </td><td>{{student.fullName() | uppercase}}</td>
</tr>
<tr>
<td>Name in Lower Case: </td><td>{{student.fullName() | lowercase}}</td>
</tr>
<tr>
<td>fees: </td><td>{{student.fees | currency}}
</td>
</tr>
<tr>
<td>Subject:</td>
<td>
<ul>
<li ng-repeat = "subject in student.subjects | filter: subjectName |orderBy:'marks'">
{{ subject.name + ', marks:' + subject.marks }}
</li>
</ul>
</td>
</tr>
</table>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Data tabel biasanya dapat diulang secara alami. ng-repeat directive bisa digunakan untuk menggambar tabel dengan mudah. Contoh berikut menyatakan penggunaan direktif ng-repeat untuk menggambar tabel.
<table>
<tr>
<th>Name</th>
<th>Marks</th>
</tr>
<tr ng-repeat = "subject in student.subjects">
<td>{{ subject.name }}</td>
<td>{{ subject.marks }}</td>
</tr>
</table>
Tabel dapat ditata menggunakan CSS Styling.
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
Contoh
Contoh berikut akan menampilkan semua direktif yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Table</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input type = "text" ng-model = "student.firstName"></td>
</tr>
<tr>
<td>Enter last name: </td>
<td>
<input type = "text" ng-model = "student.lastName">
</td>
</tr>
<tr>
<td>Name: </td>
<td>{{student.fullName()}}</td>
</tr>
<tr>
<td>Subject:</td>
<td>
<table>
<tr>
<th>Name</th>.
<th>Marks</th>
</tr>
<tr ng-repeat = "subject in student.subjects">
<td>{{ subject.name }}</td>
<td>{{ subject.marks }}</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Arahan berikut dapat digunakan untuk mengikat data aplikasi ke atribut Elemen DOM HTML.
Sr.No. | Nama & Deskripsi |
---|---|
1 | ng-disabled menonaktifkan kontrol yang diberikan. |
2 | ng-show menunjukkan kontrol yang diberikan. |
3 | ng-hide menyembunyikan kontrol yang diberikan. |
4 | ng-click mewakili acara klik AngularJS. |
ng-direktif dinonaktifkan
Tambahkan atribut ng-disabled ke tombol HTML dan berikan model. Ikat model ke kotak centang dan lihat variasinya.
<input type = "checkbox" ng-model = "enableDisableButton">Disable Button
<button ng-disabled = "enableDisableButton">Click Me!</button>
ng-show direktif
Tambahkan atribut ng-show ke tombol HTML dan berikan model. Ikat model ke kotak centang dan lihat variasinya.
<input type = "checkbox" ng-model = "showHide1">Show Button
<button ng-show = "showHide1">Click Me!</button>
ng-hide direktif
Tambahkan atribut ng-hide ke tombol HTML dan berikan model. Ikat model ke kotak centang dan lihat variasinya.
<input type = "checkbox" ng-model = "showHide2">Hide Button
<button ng-hide = "showHide2">Click Me!</button>
ng-click direktif
Tambahkan atribut ng-click ke tombol HTML dan perbarui model. Ikat model ke html dan lihat variasinya.
<p>Total click: {{ clickCounter }}</p>
<button ng-click = "clickCounter = clickCounter + 1">Click Me!</button>
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>AngularJS HTML DOM</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "">
<table border = "0">
<tr>
<td><input type = "checkbox" ng-model = "enableDisableButton">Disable Button</td>
<td><button ng-disabled = "enableDisableButton">Click Me!</button></td>
</tr>
<tr>
<td><input type = "checkbox" ng-model = "showHide1">Show Button</td>
<td><button ng-show = "showHide1">Click Me!</button></td>
</tr>
<tr>
<td><input type = "checkbox" ng-model = "showHide2">Hide Button</td>
<td><button ng-hide = "showHide2">Click Me!</button></td>
</tr>
<tr>
<td><p>Total click: {{ clickCounter }}</p></td>
<td><button ng-click = "clickCounter = clickCounter + 1">Click Me!</button></td>
</tr>
</table>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
AngularJS mendukung pendekatan modular. Modul digunakan untuk memisahkan logika, misalnya layanan, pengontrol, aplikasi, dll. Dan menjaga kode tetap bersih. Kami mendefinisikan modul dalam file js terpisah dan menamainya sesuai dengan file module.js. Dalam contoh ini kita akan membuat dua modul.
Application Module - digunakan untuk menginisialisasi aplikasi dengan pengontrol.
Controller Module - digunakan untuk menentukan pengontrol.
Modul Aplikasi
mainApp.js
var mainApp = angular.module("mainApp", []);
Di sini kami telah menyatakan aplikasi mainAppmodul menggunakan fungsi angular.module. Kami telah memberikan array kosong untuk itu. Larik ini umumnya berisi modul dependen.
Modul Pengontrol
studentController.js
mainApp.controller("studentController", function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
Di sini kami telah menyatakan pengontrol studentController modul menggunakan fungsi mainApp.controller.
Gunakan Modul
<div ng-app = "mainApp" ng-controller = "studentController">
...
<script src = "mainApp.js"></script>
<script src = "studentController.js"></script>
</div>
Di sini kita telah menggunakan modul aplikasi menggunakan direktif ng-app dan pengontrol menggunakan direktif ng-controller. Kami telah mengimpor mainApp.js dan studentController.js di halaman html utama.
Contoh
Contoh berikut akan menampilkan semua modul yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Modules</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src = "/angularjs/src/module/mainApp.js"></script>
<script src = "/angularjs/src/module/studentController.js"></script>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input type = "text" ng-model = "student.firstName"></td>
</tr>
<tr>
<td>Enter last name: </td>
<td><input type = "text" ng-model = "student.lastName"></td>
</tr>
<tr>
<td>Name: </td>
<td>{{student.fullName()}}</td>
</tr>
<tr>
<td>Subject:</td>
<td>
<table>
<tr>
<th>Name</th>
<th>Marks</th>
</tr>
<tr ng-repeat = "subject in student.subjects">
<td>{{ subject.name }}</td>
<td>{{ subject.marks }}</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
</body>
</html>
mainApp.js
var mainApp = angular.module("mainApp", []);
studentController.js
mainApp.controller("studentController", function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
AngularJS memperkaya pengisian dan validasi formulir. Kita dapat menggunakan ng-click untuk menangani tombol klik AngularJS dan menggunakan flag $ dirty dan $ invalid untuk melakukan validasi dengan cara yang tidak terlihat. Gunakan novalidate dengan deklarasi formulir untuk menonaktifkan validasi khusus browser apa pun. Kontrol formulir memanfaatkan peristiwa Angular secara berlebihan. Mari kita lihat acara-acara terlebih dahulu.
Acara
AngularJS menyediakan banyak acara yang dapat dikaitkan dengan kontrol HTML. Misalnya ng-klik biasanya dikaitkan dengan tombol. Berikut adalah acara yang didukung di Angular JS.
- ng-click
- ng-dbl-click
- ng-mousedown
- ng-mouseup
- ng-mouseenter
- ng-mouseleave
- ng-mousemove
- ng-mouseover
- ng-keydown
- ng-keyup
- ng-keypress
- ng-change
ng-klik
Setel ulang data formulir menggunakan petunjuk di-klik tombol.
<input name = "firstname" type = "text" ng-model = "firstName" required>
<input name = "lastname" type = "text" ng-model = "lastName" required>
<input name = "email" type = "email" ng-model = "email" required>
<button ng-click = "reset()">Reset</button>
<script>
function studentController($scope) {
$scope.reset = function() {
$scope.firstName = "Mahesh";
$scope.lastName = "Parashar";
$scope.email = "[email protected]";
}
$scope.reset();
}
</script>
Validasi data
Berikut ini dapat digunakan untuk melacak kesalahan.
$dirty - menyatakan bahwa nilai telah diubah.
$invalid - menyatakan bahwa nilai yang dimasukkan tidak valid.
$error - menyatakan kesalahan persisnya.
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
<form name = "studentForm" novalidate>
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input name = "firstname" type = "text" ng-model = "firstName" required>
<span style = "color:red" ng-show = "studentForm.firstname.$dirty && studentForm.firstname.$invalid">
<span ng-show = "studentForm.firstname.$error.required">First Name is required.</span>
</span>
</td>
</tr>
<tr>
<td>Enter last name: </td>
<td><input name = "lastname" type = "text" ng-model = "lastName" required>
<span style = "color:red" ng-show = "studentForm.lastname.$dirty && studentForm.lastname.$invalid">
<span ng-show = "studentForm.lastname.$error.required">Last Name is required.</span>
</span>
</td>
</tr>
<tr>
<td>Email: </td><td><input name = "email" type = "email" ng-model = "email" length = "100" required>
<span style = "color:red" ng-show = "studentForm.email.$dirty && studentForm.email.$invalid">
<span ng-show = "studentForm.email.$error.required">Email is required.</span>
<span ng-show = "studentForm.email.$error.email">Invalid email address.</span>
</span>
</td>
</tr>
<tr>
<td>
<button ng-click = "reset()">Reset</button>
</td>
<td>
<button ng-disabled = "studentForm.firstname.$dirty &&
studentForm.firstname.$invalid || studentForm.lastname.$dirty &&
studentForm.lastname.$invalid || studentForm.email.$dirty &&
studentForm.email.$invalid" ng-click="submit()">Submit</button>
</td>
</tr>
</table>
</form>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.reset = function() {
$scope.firstName = "Mahesh";
$scope.lastName = "Parashar";
$scope.email = "[email protected]";
}
$scope.reset();
});
</script>
</body>
</html>
Keluaran
Buka textAngularJS.htm di browser web. Lihat hasilnya.
HTML tidak mendukung penyematan halaman html dalam halaman html. Untuk mencapai fungsi ini, cara-cara berikut digunakan -
Using Ajax - Lakukan panggilan server untuk mendapatkan halaman html yang sesuai dan setel di innerHTML dari kontrol html.
Using Server Side Includes - JSP, PHP, dan teknologi server sisi web lainnya dapat menyertakan halaman html dalam halaman dinamis.
Dengan menggunakan AngularJS, kita dapat menyematkan halaman HTML dalam halaman HTML menggunakan direktif ng-include.
<div ng-app = "" ng-controller = "studentController">
<div ng-include = "'main.htm'"></div>
<div ng-include = "'subjects.htm'"></div>
</div>
Contoh
tryAngularJS.htm
<html>
<head>
<title>Angular JS Includes</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
<div ng-include = "'/angularjs/src/include/main.htm'"></div>
<div ng-include = "'/angularjs/src/include/subjects.htm'"></div>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
</script>
</body>
</html>
main.htm
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input type = "text" ng-model = "student.firstName"></td>
</tr>
<tr>
<td>Enter last name: </td>
<td><input type = "text" ng-model = "student.lastName"></td>
</tr>
<tr>
<td>Name: </td>
<td>{{student.fullName()}}</td>
</tr>
</table>
subjects.htm
<p>Subjects:</p>
<table>
<tr>
<th>Name</th>
<th>Marks</th>
</tr>
<tr ng-repeat = "subject in student.subjects">
<td>{{ subject.name }}</td>
<td>{{ subject.marks }}</td>
</tr>
</table>
Keluaran
Untuk menjalankan contoh ini, Anda perlu menerapkan textAngularJS.htm, main.htm, dan subjects.htm ke server web. Buka textAngularJS.htm menggunakan url server Anda di browser web. Lihat hasilnya.
AngularJS menyediakan $ https: control yang berfungsi sebagai layanan untuk membaca data dari server. Server membuat panggilan database untuk mendapatkan record yang diinginkan. AngularJS membutuhkan data dalam format JSON. Setelah data siap, $ https: dapat digunakan untuk mengambil data dari server dengan cara sebagai berikut -
function studentController($scope,$https:) {
var url = "data.txt";
$https:.get(url).success( function(response) {
$scope.students = response;
});
}
Di sini, file data.txt berisi catatan siswa. $ https: layanan membuat panggilan ajax dan menyetel respons ke siswa propertinya. Model siswa dapat digunakan untuk menggambar tabel dalam HTML.
Contoh
data.txt
[
{
"Name" : "Mahesh Parashar",
"RollNo" : 101,
"Percentage" : "80%"
},
{
"Name" : "Dinkar Kad",
"RollNo" : 201,
"Percentage" : "70%"
},
{
"Name" : "Robert",
"RollNo" : 191,
"Percentage" : "75%"
},
{
"Name" : "Julian Joe",
"RollNo" : 111,
"Percentage" : "77%"
}
]
testAngularJS.htm
<html>
<head>
<title>Angular JS Includes</title>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "" ng-controller = "studentController">
<table>
<tr>
<th>Name</th>
<th>Roll No</th>
<th>Percentage</th>
</tr>
<tr ng-repeat = "student in students">
<td>{{ student.Name }}</td>
<td>{{ student.RollNo }}</td>
<td>{{ student.Percentage }}</td>
</tr>
</table>
</div>
<script>
function studentController($scope,$http) {
var url = "data.txt";
$http.get(url).then( function(response) {
$scope.students = response.data;
});
}
</script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js">
</script>
</body>
</html>
Keluaran
Untuk menjalankan contoh ini, Anda perlu menerapkan file testAngularJS.htm dan data.txt ke server web. Buka file testAngularJS.htm menggunakan URL server Anda di web browser dan lihat hasilnya.
AngularJS mendukung Aplikasi Halaman Tunggal melalui beberapa tampilan pada satu halaman. Untuk melakukan ini AngularJS telah menyediakan arahan ng-view dan ng-template serta layanan $ routeProvider.
ng-view
tag ng-view hanya membuat placeholder di mana tampilan yang sesuai (tampilan html atau ng-template) dapat ditempatkan berdasarkan konfigurasi.
Pemakaian
Tentukan div dengan ng-view di dalam modul utama.
<div ng-app = "mainApp">
...
<div ng-view></div>
</div>
ng-template
Direktif ng-template digunakan untuk membuat tampilan html menggunakan tag script. Ini berisi atribut "id" yang digunakan oleh $ routeProvider untuk memetakan tampilan dengan pengontrol.
Pemakaian
Tentukan blok skrip dengan tipe sebagai ng-template di dalam modul utama.
<div ng-app = "mainApp">
...
<script type = "text/ng-template" id = "addStudent.htm">
<h2> Add Student </h2>
{{message}}
</script>
</div>
$ routeProvider
$ routeProvider adalah layanan utama yang menyetel konfigurasi url, memetakannya dengan halaman html atau ng-template yang sesuai, dan memasang pengontrol dengan yang sama.
Pemakaian
Tentukan blok skrip dengan modul utama dan setel konfigurasi perutean.
var mainApp = angular.module("mainApp", ['ngRoute']);
mainApp.config(['$routeProvider', function($routeProvider) {
$routeProvider
.when('/addStudent', {
templateUrl: 'addStudent.htm', controller: 'AddStudentController'
})
.when('/viewStudents', {
templateUrl: 'viewStudents.htm', controller: 'ViewStudentsController'
})
.otherwise ({
redirectTo: '/addStudent'
});
}]);
Berikut adalah poin-poin penting yang harus diperhatikan dalam contoh di atas.
$ routeProvider didefinisikan sebagai fungsi di bawah konfigurasi modul mainApp menggunakan kunci sebagai '$ routeProvider'.
$ routeProvider.when mendefinisikan url "/ addStudent" yang kemudian dipetakan ke "addStudent.htm". addStudent.htm harus ada di jalur yang sama dengan halaman html utama. Jika halaman htm tidak ditentukan maka ng-template yang akan digunakan dengan id = "addStudent.htm". Kami telah menggunakan ng-template.
"jika tidak" digunakan untuk menyetel tampilan default.
"controller" digunakan untuk menyetel pengontrol yang sesuai untuk tampilan.
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Views</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular-route.min.js">
</script>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp">
<p><a href = "#addStudent">Add Student</a></p>
<p><a href = "#viewStudents">View Students</a></p>
<div ng-view></div>
<script type = "text/ng-template" id = "addStudent.htm">
<h2> Add Student </h2>
{{message}}
</script>
<script type = "text/ng-template" id = "viewStudents.htm">
<h2> View Students </h2>
{{message}}
</script>
</div>
<script>
var mainApp = angular.module("mainApp", ['ngRoute']);
mainApp.config(['$routeProvider', function($routeProvider) {
$routeProvider
.when('/addStudent', {
templateUrl: 'addStudent.htm',
controller: 'AddStudentController'
})
.when('/viewStudents', {
templateUrl: 'viewStudents.htm',
controller: 'ViewStudentsController'
})
.otherwise({
redirectTo: '/addStudent'
});
}]);
mainApp.controller('AddStudentController', function($scope) {
$scope.message = "This page will be used to display add student form";
});
mainApp.controller('ViewStudentsController', function($scope) {
$scope.message = "This page will be used to display all the students";
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Scope adalah objek javascript khusus yang berperan untuk menggabungkan controller dengan view. Scope berisi data model. Dalam pengontrol, data model diakses melalui objek $ scope.
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller("shapeController", function($scope) {
$scope.message = "In shape controller";
$scope.type = "Shape";
});
</script>
Berikut adalah poin-poin penting yang harus diperhatikan dalam contoh di atas.
$ scope dikirimkan sebagai argumen pertama ke controller selama definisi konstruktornya.
$ scope.message dan $ scope.type adalah model yang akan digunakan di halaman HTML.
Kami telah menetapkan nilai ke model yang akan tercermin dalam modul aplikasi yang pengontrolnya adalah shapeController.
Kita juga bisa mendefinisikan fungsi di $ scope.
Cakupan Warisan
Cakupan adalah pengontrol khusus. Jika kita mendefinisikan pengontrol bersarang maka pengontrol anak akan mewarisi lingkup pengontrol induknya.
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller("shapeController", function($scope) {
$scope.message = "In shape controller";
$scope.type = "Shape";
});
mainApp.controller("circleController", function($scope) {
$scope.message = "In circle controller";
});
</script>
Berikut adalah poin-poin penting yang harus diperhatikan dalam contoh di atas.
Kami telah menetapkan nilai ke model di shapeController.
Kami telah menimpa pesan di circleController pengontrol anak. Ketika "pesan" digunakan dalam modul pengontrol circleController, pesan yang diganti akan digunakan.
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "shapeController">
<p>{{message}} <br/> {{type}} </p>
<div ng-controller = "circleController">
<p>{{message}} <br/> {{type}} </p>
</div>
<div ng-controller = "squareController">
<p>{{message}} <br/> {{type}} </p>
</div>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller("shapeController", function($scope) {
$scope.message = "In shape controller";
$scope.type = "Shape";
});
mainApp.controller("circleController", function($scope) {
$scope.message = "In circle controller";
});
mainApp.controller("squareController", function($scope) {
$scope.message = "In square controller";
$scope.type = "Square";
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
AngularJS mendukung konsep "Separation of Concerns" menggunakan arsitektur layanan. Layanan adalah fungsi javascript dan bertanggung jawab untuk melakukan tugas tertentu saja. Ini menjadikan mereka sebagai entitas individu yang dapat dipelihara dan diuji. Pengontrol, filter dapat memanggilnya sesuai kebutuhan. Layanan biasanya disuntikkan menggunakan mekanisme injeksi ketergantungan AngularJS.
AngularJS menyediakan banyak layanan bawaan misalnya, $ https :, $ rute, $ jendela, $ lokasi dll. Setiap layanan bertanggung jawab untuk tugas tertentu misalnya, $ https: digunakan untuk membuat panggilan ajax untuk mendapatkan data server. $ route digunakan untuk mendefinisikan informasi routing dan seterusnya. Layanan bawaan selalu diawali dengan simbol $.
Ada dua cara untuk membuat layanan.
- factory
- service
Menggunakan metode pabrik
Dengan menggunakan metode pabrik, pertama-tama kita mendefinisikan pabrik dan kemudian menetapkan metode untuk itu.
var mainApp = angular.module("mainApp", []);
mainApp.factory('MathService', function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b
}
return factory;
});
Menggunakan metode layanan
Menggunakan metode layanan, kami mendefinisikan layanan dan kemudian menetapkan metode untuk itu. Kami juga telah memasukkan layanan yang sudah tersedia untuk itu.
mainApp.service('CalcService', function(MathService) {
this.square = function(a) {
return MathService.multiply(a,a);
}
});
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>Angular JS Services</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 = "CalcController">
<p>Enter a number: <input type = "number" ng-model = "number" /></p>
<button ng-click = "square()">X<sup>2</sup></button>
<p>Result: {{result}}</p>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.factory('MathService', function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b
}
return factory;
});
mainApp.service('CalcService', function(MathService) {
this.square = function(a) {
return MathService.multiply(a,a);
}
});
mainApp.controller('CalcController', function($scope, CalcService) {
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Dependency Injection adalah pola desain perangkat lunak di mana komponen diberikan ketergantungannya alih-alih mengkodekannya secara keras di dalam komponen. Ini mengurangi komponen dari menemukan ketergantungan dan membuat ketergantungan dapat dikonfigurasi. Ini membantu dalam membuat komponen dapat digunakan kembali, dipelihara, dan dapat diuji.
AngularJS menyediakan mekanisme Injeksi Ketergantungan tertinggi. Ini menyediakan komponen inti berikut yang dapat disuntikkan satu sama lain sebagai dependensi.
- value
- factory
- service
- provider
- constant
nilai
value adalah objek javascript sederhana dan digunakan untuk meneruskan nilai ke kontroler selama fase konfigurasi.
//define a module
var mainApp = angular.module("mainApp", []);
//create a value object as "defaultInput" and pass it a data.
mainApp.value("defaultInput", 5);
...
//inject the value in the controller using its name "defaultInput"
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
$scope.number = defaultInput;
$scope.result = CalcService.square($scope.number);
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
pabrik
pabrik adalah fungsi yang digunakan untuk mengembalikan nilai. Ini menciptakan nilai atas permintaan setiap kali layanan atau pengontrol membutuhkan. Biasanya menggunakan fungsi pabrik untuk menghitung dan mengembalikan nilainya.
//define a module
var mainApp = angular.module("mainApp", []);
//create a factory "MathService" which provides a method multiply to return multiplication of two numbers
mainApp.factory('MathService', function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b
}
return factory;
});
//inject the factory "MathService" in a service to utilize the multiply method of factory.
mainApp.service('CalcService', function(MathService) {
this.square = function(a) {
return MathService.multiply(a,a);
}
});
...
layanan
service adalah objek javascript tunggal yang berisi sekumpulan fungsi untuk melakukan tugas tertentu. Layanan ditentukan menggunakan fungsi service () dan kemudian dimasukkan ke dalam pengontrol.
//define a module
var mainApp = angular.module("mainApp", []);
...
//create a service which defines a method square to return square of a number.
mainApp.service('CalcService', function(MathService) {
this.square = function(a) {
return MathService.multiply(a,a);
}
});
//inject the service "CalcService" into the controller
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
$scope.number = defaultInput;
$scope.result = CalcService.square($scope.number);
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
pemberi
provider digunakan oleh AngularJS secara internal untuk membuat layanan, pabrik, dll. selama fase config (fase di mana AngularJS bootstraps sendiri). Skrip yang disebutkan di bawah ini dapat digunakan untuk membuat MathService yang telah kita buat sebelumnya. Penyedia adalah metode pabrik khusus dengan metode get () yang digunakan untuk mengembalikan nilai / layanan / pabrik.
//define a module
var mainApp = angular.module("mainApp", []);
...
//create a service using provider which defines a method square to return square of a number.
mainApp.config(function($provide) {
$provide.provider('MathService', function() {
this.$get = function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b;
}
return factory;
};
});
});
konstan
konstanta digunakan untuk melewatkan nilai pada fase config dengan mempertimbangkan fakta bahwa nilai tidak dapat digunakan untuk dilewatkan selama fase config.
mainApp.constant("configParam", "constant value");
Contoh
Contoh berikut akan menampilkan semua arahan yang disebutkan di atas.
testAngularJS.htm
<html>
<head>
<title>AngularJS Dependency Injection</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "CalcController">
<p>Enter a number: <input type = "number" ng-model = "number" /></p>
<button ng-click = "square()">X<sup>2</sup></button>
<p>Result: {{result}}</p>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.config(function($provide) {
$provide.provider('MathService', function() {
this.$get = function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b;
}
return factory;
};
});
});
mainApp.value("defaultInput", 5);
mainApp.factory('MathService', function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b;
}
return factory;
});
mainApp.service('CalcService', function(MathService) {
this.square = function(a) {
return MathService.multiply(a,a);
}
});
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
$scope.number = defaultInput;
$scope.result = CalcService.square($scope.number);
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Arahan kustom digunakan di AngularJS untuk memperluas fungsionalitas HTML. Perintah kustom ditentukan menggunakan fungsi "direktif". Perintah kustom hanya menggantikan elemen yang mengaktifkannya. Aplikasi AngularJS selama bootstrap menemukan elemen yang cocok dan melakukan aktivitas satu kali menggunakan metode compile () dari direktif kustomnya, lalu memproses elemen tersebut menggunakan metode link () dari direktif kustom berdasarkan cakupan direktif tersebut. AngularJS menyediakan dukungan untuk membuat arahan kustom untuk jenis elemen berikut.
Element directives - Directive aktif ketika elemen yang cocok ditemukan.
Attribute - Directive aktif ketika atribut yang cocok ditemukan.
CSS - Directive aktif ketika gaya css yang cocok ditemukan.
Comment - Arahan aktif ketika komentar yang cocok ditemukan.
Memahami Petunjuk Kustom
Tentukan tag html kustom.
<student name = "Mahesh"></student><br/>
<student name = "Piyush"></student>
Tentukan direktif kustom untuk menangani tag html kustom di atas.
var mainApp = angular.module("mainApp", []);
//Create a directive, first parameter is the html element to be attached.
//We are attaching student html tag.
//This directive will be activated as soon as any student element is encountered in html
mainApp.directive('student', function() {
//define the directive object
var directive = {};
//restrict = E, signifies that directive is Element directive
directive.restrict = 'E';
//template replaces the complete element with its text.
directive.template = "Student: <b>{{student.name}}</b> ,
Roll No: <b>{{student.rollno}}</b>";
//scope is used to distinguish each student element based on criteria.
directive.scope = {
student : "=name"
}
//compile is called during application initialization. AngularJS calls
it once when html page is loaded.
directive.compile = function(element, attributes) {
element.css("border", "1px solid #cccccc");
//linkFunction is linked with each element with scope to get the element specific data.
var linkFunction = function($scope, element, attributes) {
element.html("Student: <b>"+$scope.student.name +"</b> ,
Roll No: <b>"+$scope.student.rollno+"</b><br/>");
element.css("background-color", "#ff00ff");
}
return linkFunction;
}
return directive;
});
Tentukan pengontrol untuk memperbarui cakupan direktif. Di sini kita menggunakan nilai atribut nama sebagai anak cakupan.
mainApp.controller('StudentController', function($scope) {
$scope.Mahesh = {};
$scope.Mahesh.name = "Mahesh Parashar";
$scope.Mahesh.rollno = 1;
$scope.Piyush = {};
$scope.Piyush.name = "Piyush Parashar";
$scope.Piyush.rollno = 2;
});
Contoh
<html>
<head>
<title>Angular JS Custom Directives</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "StudentController">
<student name = "Mahesh"></student><br/>
<student name = "Piyush"></student>
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.directive('student', function() {
var directive = {};
directive.restrict = 'E';
directive.template = "Student: <b>{{student.name}}</b> ,
Roll No: <b>{{student.rollno}}</b>";
directive.scope = {
student : "=name"
}
directive.compile = function(element, attributes) {
element.css("border", "1px solid #cccccc");
var linkFunction = function($scope, element, attributes) {
element.html("Student: <b>"+$scope.student.name +"</b> ,
Roll No: <b>"+$scope.student.rollno+"</b><br/>");
element.css("background-color", "#ff00ff");
}
return linkFunction;
}
return directive;
});
mainApp.controller('StudentController', function($scope) {
$scope.Mahesh = {};
$scope.Mahesh.name = "Mahesh Parashar";
$scope.Mahesh.rollno = 1;
$scope.Piyush = {};
$scope.Piyush.name = "Piyush Parashar";
$scope.Piyush.rollno = 2;
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
AngularJS mendukung internasionalisasi inbuilt untuk tiga jenis mata uang filter, tanggal dan angka. Kami hanya perlu memasukkan js yang sesuai sesuai dengan lokasi negara. Secara default menangani lokal browser. Misalnya, untuk menggunakan bahasa Denmark, gunakan skrip berikut.
<script src = "https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js">
</script>
Contoh menggunakan bahasa Denmark
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "StudentController">
{{fees | currency }} <br/><br/>
{{admissiondate | date }} <br/><br/>
{{rollno | number }}
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
</script>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('StudentController', function($scope) {
$scope.fees = 100;
$scope.admissiondate = new Date();
$scope.rollno = 123.45;
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
Contoh menggunakan lokal Browser
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "StudentController">
{{fees | currency }} <br/><br/>
{{admissiondate | date }} <br/><br/>
{{rollno | number }}
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<!-- <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
</script> -->
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('StudentController', function($scope) {
$scope.fees = 100;
$scope.admissiondate = new Date();
$scope.rollno = 123.45;
});
</script>
</body>
</html>
Hasil
Buka textAngularJS.htm di browser web. Lihat hasilnya.
AngularJS mendukung internasionalisasi inbuilt untuk tiga jenis filter: Mata Uang, Tanggal, dan Angka. Kami hanya perlu memasukkan skrip java yang sesuai sesuai dengan lokasi negara. Secara default, ini menganggap lokal browser. Misalnya, untuk lokal Denmark, gunakan skrip berikut -
<script src = "https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js">
</script>
Contoh Menggunakan Bahasa Denmark
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "StudentController">
{{fees | currency }} <br/><br/>
{{admissiondate | date }} <br/><br/>
{{rollno | number }}
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
</script>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('StudentController', function($scope) {
$scope.fees = 100;
$scope.admissiondate = new Date();
$scope.rollno = 123.45;
});
</script>
</body>
</html>
Keluaran
Buka file testAngularJS.htm di web browser dan lihat hasilnya.
Contoh Menggunakan Lokal Browser
testAngularJS.htm
<html>
<head>
<title>Angular JS Forms</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "StudentController">
{{fees | currency }} <br/><br/>
{{admissiondate | date }} <br/><br/>
{{rollno | number }}
</div>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
<!-- <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
</script> -->
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('StudentController', function($scope) {
$scope.fees = 100;
$scope.admissiondate = new Date();
$scope.rollno = 123.45;
});
</script>
</body>
</html>
Keluaran
Buka file testAngularJS.htm di web browser dan lihat hasilnya.