jQuery добавляет параметры в url
мне нравится, как jQuery $.метод ajax () позволяет указать url запроса:
{
url: 'http://domain.com/?param=1',
data{
param2: '2'
}
}
$.метод ajax () будет (вероятно) вызывать $.param () на предоставленных данных и необязательно добавить его к предоставленному URL.
мой вопрос: доступен ли этот тип манипуляции url за пределами $.ajax () вызов?
например, я хочу открыть всплывающее окно, и я хотел бы построить URL так же, как я делаю с $.Аякс.)(
Я написал функцию что делает это, но у меня такое чувство, что я изобретаю колесо и дублирую уже существующую функцию jQuery:
var prepareUrl = function( url, data )
{
var params = $.param( data );
if ( params.length > 0 )
{
// url contains a query string
if ( url.indexOf( '?' ) > -1 )
{
// get last char of url
var lastChar = url.substr( url.length - 1 );
// Append & to the end of url if required
if ( lastChar != '&' && lastChar != '?' )
{
url += '&';
}
}
else // url doesn't contain a query string
{
url += '?';
}
url += params;
}
return url;
}
спасибо!
4 ответов
поскольку других ответов не ответили на мой вопрос, я сделал несколько тестов с $.ajax()
вызов, чтобы увидеть, как он объединяет URL-адреса с данными param.
мои выводы до сих пор:
- если url содержит
?
, потом$.ajax()
добавляет'&'
+$.param(data)
- если нет, то
$.ajax()
добавляет'?'
+$.param(data)
поэтому, если я хочу, чтобы моя функция обработки url соответствовала пути $.ajax()
делает это, тогда он должен будьте чем-то вроде следующего:
var addParams = function( url, data )
{
if ( ! $.isEmptyObject(data) )
{
url += ( url.indexOf('?') >= 0 ? '&' : '?' ) + $.param(data);
}
return url;
}
мне все еще интересно, есть ли встроенный метод jQuery для этого.
вы можете построить строку запроса такой:
getQueryStr = function(obj) {
var str = [];
for (var p in obj)
if (obj.hasOwnProperty(p)) {
str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
}
return str.join("&");
}
console.log(serialize({
param1: "val1",
param2: "val2"
}));
для рекурсивной :
getQueryStr = function(obj, prefix) {
var str = [];
for (var p in obj) {
if (obj.hasOwnProperty(p)) {
var k = prefix ? prefix + "[" + p + "]" : p,
v = obj[p];
str.push(typeof v == "object" ?
getQueryStr(v, k) :
encodeURIComponent(k) + "=" + encodeURIComponent(v));
}
}
return str.join("&");
}
console.log(serialize({
favfruit: "apple",
data: {
name: 'js',
points: [1, 2, 3]
}
}));
на param
метод создаст строку запроса для вас, но вам нужно будет удалить существующую строку запроса.
var base = "http://example.com/foo/?example=old";
var data = {
foo: "hello",
bar: "world?"
};
var url = base.replace(/\?.*$/, "") + "?" + jQuery.param(data);
alert(url);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>