Як я можу перевірити, чи містить рядок запиту q=в ньому за допомогою JavaScript або jQuery?
Відповіді:
var field = 'q';
var url = window.location.href;
if(url.indexOf('?' + field + '=') != -1)
return true;
else if(url.indexOf('&' + field + '=') != -1)
return true;
return false
?kodiaq=1, тоді виклик url.indexOf('q=')без префіксу &або ?може призвести вас до думки, що qпараметр присутній.
Ви також можете використовувати регулярний вираз:
/[?&]q=/.test(location.search)
if(/[?&]q=/.test(location.search)) { alert("match"); }(я був трохи розгублений через коментар @DragosDurlut. :)
Використання URL:
url = new URL(window.location.href);
if (url.searchParams.get('test')) {
}
EDIT: якщо вам сумно щодо сумісності, я настійно рекомендую https://github.com/medialize/URI.js/ .
Простий зразок коду JavaScript, який буквально відповідає на ваше запитання:
return location.search.indexOf('q=')>=0;
Звичайний зразок коду JavaScript, який намагається знайти, чи існує параметр q і чи має значення:
var queryString=location.search;
var params=queryString.substring(1).split('&');
for(var i=0; i<params.length; i++){
var pair=params[i].split('=');
if(decodeURIComponent(pair[0])=='q' && pair[1])
return true;
}
return false;
fooq=bar
ще один варіант, але майже такий самий, як розчин Гумбоса:
var isDebug = function(){
return window.location.href.search("[?&]debug=") != -1;
};
Спробуйте це
//field "search";
var pattern = /[?&]search=/;
var URL = location.search;
if(pattern.test(URL))
{
alert("Found :)");
}else{
alert("Not found!");
}
У сучасних браузерах це стало набагато простіше завдяки URLSearchParamsінтерфейсу. Це визначає безліч корисних методів для роботи із рядком запиту URL-адреси.
Припускаючи, що наша URL-адреса є https://example.com/?product=shirt&color=blue&newuser&size=m, ви можете отримати рядок запиту, використовуючи window.location.search:
const queryString = window.location.search;
console.log(queryString);
// ?product=shirt&color=blue&newuser&size=m
Потім ви можете проаналізувати параметри рядка запиту, використовуючи URLSearchParams:
const urlParams = new URLSearchParams(queryString);
Тоді ви можете викликати будь-який з його методів на результат.
Наприклад, URLSearchParams.get()поверне перше значення, пов'язане з заданим параметром пошуку:
const product = urlParams.get('product')
console.log(product);
// shirt
const color = urlParams.get('color')
console.log(color);
// blue
const newUser = urlParams.get('newuser')
console.log(newUser);
// empty string
Ви можете використовувати, URLSearchParams.has()щоб перевірити, чи існує певний параметр:
console.log(urlParams.has('product'));
// true
console.log(urlParams.has('paymentmethod'));
// false
Для подальшого читання натисніть тут .
Я раніше користувався цією бібліотекою, яка досить добре справляється з тим, що ви шукаєте. Зокрема: -
qs.contains(name)
Returns true if the querystring has a parameter name, else false.
if (qs2.contains("name1")){ alert(qs2.get("name1"));}
Це має допомогти:
function getQueryParams(){
try{
url = window.location.href;
query_str = url.substr(url.indexOf('?')+1, url.length-1);
r_params = query_str.split('&');
params = {}
for( i in r_params){
param = r_params[i].split('=');
params[ param[0] ] = param[1];
}
return params;
}
catch(e){
return {};
}
}
var url = new URLSearchParams(location.search); url.has("my_great_query");повертає,trueякщо цей рядок запиту є у вашій URL- адресі . Потім ви можете отримати його значення за допомогоюurl.get("my_great_query");.