2017-07-31 188 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>