关于$ location.search,docs说,
在没有任何参数的情况下调用时返回当前url的搜索部分(作为对象)。
在我的网址中,我的查询字符串有一个没有值的参数'?test_user_bLzgB'。 '$ location.search()'也返回一个对象。我如何获得实际文本?
答案 0 :(得分:147)
不确定自接受的答案被接受后它是否已经改变,但是有可能。
$location.search()
将返回一个键值对的对象,与查询字符串相同的对。没有值的键只是作为true存储在对象中。在这种情况下,对象将是:
{"test_user_bLzgB": true}
您可以使用$location.search().test_user_bLzgB
示例(包含较大的查询字符串):http://fiddle.jshell.net/TheSharpieOne/yHv2p/4/show/?test_user_bLzgB&somethingElse&also&something=Somethingelse
注意:由于哈希(因为它将转到http://fiddle.jshell.net/#/url,这将创建一个新的小提琴),这个小提琴将无法在不支持js历史记录的浏览器中工作(在IE< 10中不起作用) )
编辑:
正如@Naresh和@DavidTchepak的评论中指出的那样,$locationProvider
也需要正确配置:https://code.angularjs.org/1.2.23/docs/guide/$location#-location-service-configuration
答案 1 :(得分:48)
如果您只需要将查询字符串视为文本,则可以使用:$window.location.search
答案 2 :(得分:37)
$location.search()
返回一个对象,由键作为变量,值作为其值。
所以:如果你写这样的查询字符串:
?user=test_user_bLzgB
你可以很容易地得到这样的文字:
$location.search().user
如果你不想使用密钥,值如?foo = bar,我建议使用散列#test_user_bLzgB,
并致电
$location.hash()
将返回'test_user_bLzgB',这是您要检索的数据。
其他信息:
如果你使用查询字符串方法,并且你得到一个带有$ location.search()的空对象, 这可能是因为Angular正在使用hashbang策略而不是html5策略... 要使其正常工作,请将此配置添加到您的模块
yourModule.config(['$locationProvider', function($locationProvider){
$locationProvider.html5Mode(true);
}]);
答案 3 :(得分:13)
首先使URL格式正确,以便使查询字符串使用#?q = string 对我有用
http://localhost/codeschool/index.php#?foo=abcd
将$ location服务注入控制器
app.controller('MyController', [ '$location', function($location) {
var searchObject = $location.search();
// $location.search(); reutrn object
// searchObject = { foo = 'abcd' };
alert( searchObject.foo );
} ]);
因此输出应该是 abcd
答案 4 :(得分:10)
你也可以使用它
function getParameterByName(name) {
name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"),
results = regex.exec(location.search);
return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
}
var queryValue = getParameterByName('test_user_bLzgB');
答案 5 :(得分:9)
如果$location.search()
无效,请确保您拥有以下内容:
1)在应用程序的模块配置
中配置html5Mode(true)
appModule.config(['$locationProvider', function($locationProvider) {
$locationProvider.html5Mode(true);
}]);
2)您的HTML中存在<base href="/">
<head>
<base href="/">
...
</head>
参考文献:
答案 6 :(得分:7)
Angular不支持这种查询字符串。
URL的查询部分应该是&
- 分隔的键值对序列,因此可以完美地解释为对象。
根本没有API来管理不代表键值对集的查询字符串。
答案 7 :(得分:0)
在我的NodeJS示例中,我有一个网址“localhost:8080 / Lists / list1.html?x1 = y”,我想遍历并获取值。
为了使用$ location.search()来获取x1 = y,我做了一些事情
我的list1.js有
var app = angular.module('NGApp', ['ngRoute']); //dependencies : ngRoute
app.config(function ($locationProvider) { //config your locationProvider
$locationProvider.html5Mode(true).hashPrefix('');
});
app.controller('NGCtrl', function ($scope, datasvc, $location) {// inject your location service
//var val = window.location.href.toString().split('=')[1];
var val = $location.search().x1; alert(val);
$scope.xout = function () {
datasvc.out(val)
.then(function (data) {
$scope.x1 = val;
$scope.allMyStuffs = data.all;
});
};
$scope.xout();
});
和我的list1.html有
<head>
<base href=".">
</head>
<body ng-controller="NGCtrl">
<div>A<input ng-model="x1"/><br/><textarea ng-model="allMyStuffs"/></div>
<script src="../js/jquery-2.1.4.min.js"></script>
<script src="../js/jquery-ui.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.9/angular.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.9/angular-route.js"></script>
<script src="../js/bootstrap.min.js"></script>
<script src="../js/ui-bootstrap-tpls-0.14.3.min.js"></script>
<script src="list1.js"></script>
</body>
答案 8 :(得分:0)
我的修复更简单,创建工厂,并作为一个变量实现。例如
angular.module('myApp', [])
// This a searchCustom factory. Copy the factory and implement in the controller
.factory("searchCustom", function($http,$log){
return {
valuesParams : function(params){
paramsResult = [];
params = params.replace('(', '').replace(')','').split("&");
for(x in params){
paramsKeyTmp = params[x].split("=");
// Si el parametro esta disponible anexamos al vector paramResult
if (paramsKeyTmp[1] !== '' && paramsKeyTmp[1] !== ' ' &&
paramsKeyTmp[1] !== null){
paramsResult.push(params[x]);
}
}
return paramsResult;
}
}
})
.controller("SearchController", function($scope, $http,$routeParams,$log,searchCustom){
$ctrl = this;
var valueParams = searchCustom.valuesParams($routeParams.value);
valueParams = valueParams.join('&');
$http({
method : "GET",
url: webservice+"q?"+valueParams
}).then( function successCallback(response){
data = response.data;
$scope.cantEncontrados = data.length;
$scope.dataSearch = data;
} , function errorCallback(response){
console.log(response.statusText);
})
})
<html>
<head>
</head>
<body ng-app="myApp">
<div ng-controller="SearchController">
<form action="#" >
<input ng-model="param1"
placeholder="param1" />
<input ng-model="param2"
placeholder="param2"/>
<!-- Implement in the html code
(param1={{param1}}¶m2={{param2}}) -> this is a one variable, the factory searchCustom split and restructure in the array params
-->
<a href="#seach/(param1={{param1}}¶m2={{param2}})">
<buttom ng-click="searchData()" >Busqueda</buttom>
</a>
</form>
</div>
</body>
答案 9 :(得分:0)
很晚才回答:(但是对于有需要的人, 可以使用Angular js也可以:) URLSearchParams 让我们看看如何使用这个新的API从位置获取值!
//假设“?post = 1234&action = edit”
var urlParams = new URLSearchParams(window.location.search);
console.log(urlParams.has('post')); // true
console.log(urlParams.get('action')); // "edit"
console.log(urlParams.getAll('action')); // ["edit"]
console.log(urlParams.toString()); // "?post=1234&action=edit"
console.log(urlParams.append('active', '1')); // "?
post=1234&action=edit&active=1"
使用此功能代替 URLSearchParams
urlParam = function (name) {
var results = new RegExp('[\?&]' + name + '=([^&#]*)')
.exec(window.location.search);
return (results !== null) ? results[1] || 0 : false;
}
console.log(urlParam('action')); //edit