詳解AngularJS1.6版本中ui-router路由中/#!/的解決方法
AngularJS 路由 是通過 # + 標記 幫助我們區(qū)分不同的邏輯頁面并將不同的頁面綁定到對應的控制器上。因此在設置好路由規(guī)則后,為html頁面的a標簽設置href路由鏈接切換不同的視圖。Angular1.6版本之前通常有href=“#...”或href=“#/...”這兩種寫法,結果這兩種寫法在Angular1.6中沒有任何反應。
結果查看了下瀏覽器地址欄,默認視圖鏈接竟然顯示“#!/..”,是的,中間多加了個!號。
AngularJS升級到了1.6版本后,里面多了很多/#!/的改動。那么1.6究竟做了哪些改變呢?可以參考這個:https://github.com/angular/angular.js/commit/aa077e81129c740041438688dff2e8d20c3d7b52
解決方案一:
所以在html頁面a標簽上將href的屬性值添加一個!號就可以了。
<p><a href="#!/addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> <p><a href="#!/viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p>
完整代碼:
<html> <head> <meta charset="utf-8" /> <title>AngularJS 視圖</title> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular-route.min.js"></script> </head> <body> <h2>AngularJS 視圖</h2> <div ng-app="mainApp"> <p><a href="#!/addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> <p><a href="#!/viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> <div ng-view></div> <script type="text/ng-template" id="addStudent.html"> <h2>添加學生</h2> {{message}} </script> <script type="text/ng-template" id="viewStudents.html"> <h2>查看學生</h2> {{message}} </script> </div> <script> var mainApp=angular.module("mainApp",['ngRoute']); mainApp.config(["$routeProvider",function($routeProvider){ $routeProvider.when('/addStudent',{ templateUrl:'addStudent.html', controller:'AddStudentController' }).when('/viewStudents',{ templateUrl:'viewStudents.html', controller:'ViewStudentsController' }).otherwise({ redirectTo:'/addStudent' }); }]); mainApp.controller("AddStudentController",function($scope){ $scope.message="這個頁面是用于顯示學生信息的輸入表單"; }); mainApp.controller("ViewStudentsController",function($scope){ $scope.message="這個頁面是用于顯示所有學生信息"; }); </script> </body> </html>
解決方案二:
如果想讓路由依舊表現的與之前版本的一致可以這樣做:
mainApp.config(["$locationProvider","$routeProvider",function($locationProvider,$routeProvider){ $locationProvider.hashPrefix(''); }]);
<p><a href="#addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> <p><a href="#viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p>
完整代碼:
<html> <head> <meta charset="utf-8" /> <title>AngularJS 視圖</title> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.1/angular-route.min.js"></script> </head> <body> <h2>AngularJS 視圖</h2> <div ng-app="mainApp"> <p><a href="#addStudent" rel="external nofollow" rel="external nofollow" >添加學生</a></p> <p><a href="#viewStudents" rel="external nofollow" rel="external nofollow" >查看學生</a></p> <div ng-view></div> <script type="text/ng-template" id="addStudent.html"> <h2>添加學生</h2> {{message}} </script> <script type="text/ng-template" id="viewStudents.html"> <h2>查看學生</h2> {{message}} </script> </div> <script> var mainApp=angular.module("mainApp",['ngRoute']); mainApp.config(["$locationProvider","$routeProvider",function($locationProvider,$routeProvider){ $locationProvider.hashPrefix(''); $routeProvider.when('/addStudent',{ templateUrl:'addStudent.html', controller:'AddStudentController' }).when('/viewStudents',{ templateUrl:'viewStudents.html', controller:'ViewStudentsController' }).otherwise({ redirectTo:'/addStudent' }); }]); mainApp.controller("AddStudentController",function($scope){ $scope.message="這個頁面是用于顯示學生信息的輸入表單"; }); mainApp.controller("ViewStudentsController",function($scope){ $scope.message="這個頁面是用于顯示所有學生信息"; }); </script> </body> </html>
這樣瀏覽器訪問時,就不會多出個!號了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
AngularJS實現的select二級聯動下拉菜單功能示例
這篇文章主要介紹了AngularJS實現的select二級聯動下拉菜單功能,結合完整實例形式分析了AngularJS實現二級聯動菜單的具體操作步驟與相關實現技巧,需要的朋友可以參考下2017-10-10AngularJs Understanding Angular Templates
本文主要介紹AngularJs Understanding Angular Templates的資料,這里整理了詳細的資料及簡單示例代碼,有興趣的小伙伴的參考下2016-09-09angularjs封裝bootstrap時間插件datetimepicker
這篇文章主要介紹了angularjs封裝bootstrap時間插件datetimepicker 的相關資料,需要的朋友可以參考下2016-06-06AngularJs html compiler詳解及示例代碼
本文主要介紹AngularJs html compiler的知識講解,這里整理了相關資料及相關示例代碼,有興趣的小伙伴可以參考下2016-09-09