时间:2021-05-25
AngularJS 路由 是通过 # + 标记 帮助我们区分不同的逻辑页面并将不同的页面绑定到对应的控制器上。因此在设置好路由规则后,为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>这样浏览器访问时,就不会多出个!号了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
什么是ui-router ui-router是AngularUI库最有用的组件之一(AngularUI库由AngularJS社区构建)。它是一个第三方路由框架
本文实例讲述了AngularJS路由Ui-router模块用法。分享给大家供大家参考,具体如下:由于某些设计原因,AngularJS原生的路由模块有一些缺点,比
关于ui-router中嵌套路由中的问题1.首先我们的页面层次为其中Main.html是我们的主页,我们要在main.html中对路由进行统一的管理。main.
前言React-Router已经发布了多个版本,利用路由导航的使用方法都不大一样,在这里总结一下。React-Router2.0.0版本2.0.0版本需要使用b
html页面代码 需要引用的ui.router.js文件app.js将UI-Router作为web应用的依赖,注入到主程序:url:url选项将会为该