2017-07-31 137 views
0

我想提取我的网址查询字符串使用$location像这样example。 我的网址 - http://someDomain.com/create/index.jsp?queryToken=123abc

,并在我的指令:

vm.queryParam = $location.search(); 
$log.log('vm.queryParam', vm.queryParam); //{} 
vm.details.query = vm.queryParam.queryToken; 
$log.log('vm.queryToken', vm.details.query); //undefined 

登录$location但究竟是提取它们的时候search()不工作正确的方式,当我看到param或PARAMS?

谢谢。

+0

即j ust返回我的网址。 –

+0

得到任何错误? – anu

+0

不,我是一个角... –

回答

0

$ location.search()仅适用于打开HTML5模式。
凡定义你的路由加入这一行:

$locationProvider.html5Mode(true); 

这工作总是:

$window.location.search 
+0

_ $ location.search()只能用于HTML5模式打开它也可以在HTML5模式下关闭。 – George

2

我已经使用这个和它的作品,请尝试使用此

var app = angular.module('myApp', []); 
 
app.config(['$locationProvider', function($locationProvider){ 
 
$locationProvider.html5Mode({ 
 
    enabled: true, 
 
    requireBase: false 
 
    }) 
 
}]) 
 
app.controller('myCtrl', function($scope, $location) { 
 
$scope.myPeram = "pass some value in url ?myParam=123"; 
 
\t \t var query = $location.search(); 
 
    if(query.myParam) 
 
    $scope.myPeram = query.myParam; 
 
    
 
});
<!DOCTYPE html> 
 
<html> 
 
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.20/angular.min.js"></script> 
 

 
</script> 
 
<body> 
 

 
<div ng-app="myApp" ng-controller="myCtrl"> 
 
<span ng-bind="myPeram"></span> 
 

 

 
</div> 
 
</body> 
 
</html>