關于ui-router中嵌套路由中的問題
1.首先我們的頁面層次為
其中Main.html是我們的主頁,我們要在main.html中對路由進行統一的管理。
main.html頁面中有一個ui-view在這里將填充PageTab.html,同時被填充的PageTab.html中也有一個ui-view
這樣就實現了嵌套路由。
最終效果:
當我們點擊Page-1時出現的是Page1中的內容,同理點擊Page-2。
下面是實際的代碼:
Main.html
<!DOCTYPE html><html ng-app="myApp"><head><meta charset="UTF-8"><title></title><script src="js/angular.min.js"></script><script src="js/angular-ui-router.js"></script><script> </script></head><body><h3>Main page</h3> <div> <div ui-view></div> </div><script> angular.module("myApp",["ui.router"]) .config(function($stateProvider){ $stateProvider .state("PageTab",{ url:"", templateUrl:"PageTab.html" }) .state("PageTab.Page1",{ url:"/Page1", templateUrl:"Page1.html" }) .state("PageTab.Page2",{ url:"/Page2", templateUrl:"Page2.html" }) })</script></body></html>
PageTab.html
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>Insert title here</title></head><body><h2>PageTab</h2> <div> <span style="width:100px" ui-sref=".Page1"><a href="">Page-1</a></span> <span style="width:100px" ui-sref=".Page2"><a href="">Page-2</a></span> </div> <div ui-view=""></div></body></html>
Page1.html
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>Page1</title></head><body> <h2>Page1</h2></body></html>
Page2.html
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>Page2</title></head><body> <h2>Page2</h2></body></html>
以上是全部的頁面代碼,Main.html中js庫需要手動導入。
下面我們重點看Main.html中對路由統一管理的部分也就是這段js代碼
<script> angular.module("myApp",["ui.router"]) .config(function($stateProvider){ $stateProvider .state("PageTab",{ url:"", templateUrl:"PageTab.html" }) .state("PageTab.Page1",{ url:"/Page1", templateUrl:"Page1.html" }) .state("PageTab.Page2",{ url:"/Page2", templateUrl:"Page2.html" }) })</script>
一共三個狀態:
第一個狀態
.state("PageTab",{ url:"", templateUrl:"PageTab.html" })
在第一個中我們定義了初始狀態名為PageTab,url狀態為空,這時候在母版中將會在ui-view中填充PageTab.html這個頁面。
第二個狀態
.state("PageTab.Page1",{ url:"/Page1", templateUrl:"Page1.html" })
我們把這個狀態名字命名為PageTab.Page1 這時候的路由將會交給PageTab來處理,即在PageTab.html頁面中的ui-view中填充Page1.html中的內容。同理如果state命名為PageTab.Page2 那么處理它的就會是PageTab.html這個頁面。
希望本文所述對你有所幫助,angularjs ui-router中路由的二級嵌套就給大家介紹到這里了。希望大家繼續關注我們的網站!想要學習angularjs可以繼續關注本站。
新聞熱點
疑難解答