Rumah > hujung hadapan web > tutorial js > Terangkan secara ringkas definisi dan penggunaan AngularJS Routing_AngularJS

Terangkan secara ringkas definisi dan penggunaan AngularJS Routing_AngularJS

WBOY
Lepaskan: 2016-05-16 15:12:02
asal
1452 orang telah melayarinya

Dalam aplikasi satu halaman, melompat antara paparan adalah sangat penting Memandangkan aplikasi menjadi semakin kompleks, kami memerlukan kaedah untuk mengawal dengan tepat masa dan halaman yang perlu dipersembahkan kepada pengguna.

Kami boleh menyokong penukaran antara halaman yang berbeza dengan memperkenalkan templat yang berbeza ke dalam halaman utama, tetapi kelemahan berbuat demikian ialah semakin banyak kod terbenam menyukarkan untuk mengurus akhirnya.

Kami boleh menyepadukan banyak templat ke dalam paparan melalui arahan ng-include, tetapi kami mempunyai cara yang lebih baik untuk menangani situasi ini Kami boleh membahagikan paparan kepada paparan reka letak dan templat, dan kemudian mengikut URL akses pengguna tertentu untuk memaparkan paparan yang diingini

Kita boleh meletakkan "kepingan" ini bersama-sama dalam templat reka letak

AngularJS melaksanakan idea di atas dengan mengisytiharkan laluan pada $routeProvider (penyedia perkhidmatan $route)

Menggunakan $routeProvider, kami boleh menggunakan API sejarah penyemakan imbas dengan lebih baik dan membenarkan pengguna menyimpan laluan semasa sebagai penanda halaman untuk kegunaan masa hadapan

Untuk menyediakan penghalaan dalam aplikasi kami, kami perlu melakukan dua perkara: Pertama, kami perlu menunjukkan tempat kami akan menyimpan templat reka letak di mana kandungan halaman baharu akan disimpan. Sebagai contoh, jika kita ingin menambah pengepala dan pengaki pada semua halaman, kita boleh mereka bentuk templat reka letak seperti ini:

<header>
 <h1>Header</h1>
</header>
<div class="content">
 <div ng-view></div>
</div>
<footer>
 <h5>Footer</h5>
</footer>
Salin selepas log masuk

Arahan ng-view akan menggunakan $routeProvider berkelajuan tinggi tempat untuk memaparkan templat

Kedua, kami perlu mengkonfigurasi maklumat penghalaan kami, kami akan mengkonfigurasi $routeProvider dalam aplikasi

$routeProvider menyediakan dua kaedah untuk mengendalikan penghalaan: bila dan sebaliknya. Kaedah apabila menerima dua parameter, yang pertama ditetapkan $location.path() (Tiada masalah jika anda menggunakan "//" secara langsung)


Takrif
Sangat mudah untuk menentukan laluan, hanya masukkan kebergantungan ngRoute ke dalam modul utama aplikasi kami

angular.module('myApp', ['ngRoute'])
 .config(function($routeProvider) {});

Salin selepas log masuk

Kini, kami boleh menentukan laluan untuk aplikasi. $routeProvider disuntik ke dalam kaedah .config() dalam modul penghalaan Kod di atas menunjukkan kepada kita dua kaedah untuk menentukan laluan.

bila()

Kaedah when() mempunyai dua parameter, url penyemak imbas yang kami mahu padankan dan objek operasi penghalaan. Secara amnya, laluan utama sering diwakili oleh "/", dan parameter URL juga boleh ditakrifkan Dalam pengawal, $routeParams digunakan untuk mendapatkan parameter url.

templateUrl: lihat templat yang mewakili lompatan laluan

pengawal: pengawal

angular.module('myApp', ['ngRoute'])
  .config(function($routeProvider) {
   $routeProvider
    .when('/', {
     templateUrl: 'views/main.html',
     controller: 'MainCtrl'
    })
    .when('/day/:id', {
     templateUrl: 'views/day.html',
     controller: 'DayCtrl'
    })
Salin selepas log masuk

jika tidak()

jika tidak() mentakrifkan laluan untuk melompat ke apabila aplikasi tidak dapat mencari laluan yang ditentukan

angular.module('myApp', ['ngRoute'])
.config(function($routeProvider) {
 $routeProvider
  .when('/', {
   templateUrl: 'views/main.html',
   controller: 'MainCtrl'
  })
  .when('/day/:id', {
   templateUrl: 'views/day.html',
   controller: 'DayCtrl'
  })
  .otherwise({
   redirectTo: '/'
  });
})

Salin selepas log masuk

Gunakan
Bagaimana untuk menggunakan laluan yang ditentukan? Kita perlu memberitahu sudut mana bahagian halaman yang ingin kita tukar, yang memerlukan penggunaan arahan ng-view

<div class="header">My page</div>
<div ng-view></div>
<span class="footer">A footer</span>

Salin selepas log masuk

Dengan cara ini, hanya

akan dikemas kini dan pengepala/pengaki akan sentiasa kekal tidak berubah

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan