q=JavaScript veya jQuery kullanarak sorgu dizesinin içinde a içerip içermediğini nasıl kontrol edebilirim ?
Yanıtlar:
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çağırmak veya parametrenin mevcut olduğuna inanmanıza neden olur . url.indexOf('q=')&?q
Ayrıca normal bir ifade de kullanabilirsiniz:
/[?&]q=/.test(location.search)
if(/[?&]q=/.test(location.search)) { alert("match"); }(@DragosDurlut yorumu yüzünden biraz kafam karıştı. :)
Kullanarak URL:
url = new URL(window.location.href);
if (url.searchParams.get('test')) {
}
DÜZENLEME: Uyumluluk konusunda üzgünseniz, https://github.com/medialize/URI.js/'yi şiddetle tavsiye ederim .
Sorunuzu tam anlamıyla yanıtlayan basit javascript kodu örneği:
return location.search.indexOf('q=')>=0;
Q parametresinin var olup olmadığını ve bir değeri olup olmadığını bulmaya çalışan düz javascript kodu örneği:
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
bir varyant daha, ancak neredeyse Gumbos çözümüyle aynı:
var isDebug = function(){
return window.location.href.search("[?&]debug=") != -1;
};
Bunu dene
//field "search";
var pattern = /[?&]search=/;
var URL = location.search;
if(pattern.test(URL))
{
alert("Found :)");
}else{
alert("Not found!");
}
Modern tarayıcılarda, URLSearchParamsarayüz sayesinde bu çok daha kolay hale geldi . Bu, bir URL'nin sorgu dizesiyle çalışmak için bir dizi yardımcı program yöntemi tanımlar.
URL'mizin olduğunu varsayarsak, şunu https://example.com/?product=shirt&color=blue&newuser&size=mkullanarak sorgu dizesini alabilirsiniz window.location.search:
const queryString = window.location.search;
console.log(queryString);
// ?product=shirt&color=blue&newuser&size=m
Daha sonra sorgu dizesinin parametrelerini şu şekilde ayrıştırabilirsiniz URLSearchParams:
const urlParams = new URLSearchParams(queryString);
Ardından, sonuç üzerinde herhangi bir yöntemini çağırabilirsiniz.
Örneğin URLSearchParams.get(), verilen arama parametresiyle ilişkili ilk değeri döndürür:
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()Belirli bir parametrenin var olup olmadığını kontrol etmek için kullanabilirsiniz :
console.log(urlParams.has('product'));
// true
console.log(urlParams.has('paymentmethod'));
// false
Daha fazla okumak için lütfen buraya tıklayın .
Daha önce bu kütüphaneyi kullandım, bu da peşinde olduğunuz şey için oldukça iyi bir iş çıkarıyor. Özellikle: -
qs.contains(name)
Returns true if the querystring has a parameter name, else false.
if (qs2.contains("name1")){ alert(qs2.get("name1"));}
Bu yardımcı olmalı:
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");dönertrue. Daha sonra değerini alabilirsinizurl.get("my_great_query");.