内容简介:翻译自:https://stackoverflow.com/questions/27352371/cannot-get-current-route-location-path-returns-empty
我目前在/ addDoc,我想要当前的路线.这是我的控制器:
app.controller('DocRegistrationController',[ '$http', '$scope', '$upload', '$location', function($http, $scope, $upload, $location){ $scope.validation=function(){ alert($location.path()); } }
但是它返回空.我不想硬编码所有路线.我究竟做错了什么?
$location服务响应解析浏览器地址栏中的URL并使URL可用于您的APP.
因为您使用常规URL路径和搜索段,所以必须将$locationProvider html5Mode设置为true.
$locationProvider将使用hashbang作为默认模式.
如果未将html5Mode设置为true,则在尝试获取url路径时将获得空字符串.
然后在设置html5Mode之后使用$location服务获取url路径.
并编写自己的规则来处理路径.
假设您的完整网址如下所示: http://example.com/person/show/321
Main.js
angular.module("MyAPP",[],function($locationProvider){ $locationProvider.html5Mode(true); }); function MainController($location){ var pId = $location.path().split("/")[3]||"Unknown"; //path will be /person/show/321/, and array looks like: ["","person","show","321",""] console.log(pId); }
的index.html
<!DOCTYPE html> <html lang="en" ng-app="MyAPP"> <head> <meta charset="utf-8"> <title>Angular test</title> </head> <body ng-controller="MainController"> <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.6/angular.min.js"></script> <script src="js/main.js"></script> </body> </html>
希望这对你有所帮助.
翻译自:https://stackoverflow.com/questions/27352371/cannot-get-current-route-location-path-returns-empty
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
疯狂Java讲义(第4版)
李刚 / 电子工业出版社 / 2018-1 / 109
《疯狂Java讲义(第4版)》是《疯狂Java讲义》的第4版,第4版保持了前3版系统、全面、讲解浅显、细致的特性,全面新增介绍了Java 9的新特性。 《疯狂Java讲义(第4版)》深入介绍了Java编程的相关方面,《疯狂Java讲义(第4版)》内容覆盖了Java的基本语法结构、Java的面向对象特征、Java集合框架体系、Java泛型、异常处理、Java GUI编程、JDBC数据库编程、J......一起来看看 《疯狂Java讲义(第4版)》 这本书的介绍吧!