JavaScript'teki istekten "GET" değişkenleri nasıl alınır?
JQuery veya YUI! bu özellik yerleşik mi?
JavaScript'teki istekten "GET" değişkenleri nasıl alınır?
JQuery veya YUI! bu özellik yerleşik mi?
Yanıtlar:
Tüm veriler altında mevcuttur
window.location.search
dizeyi çözümlemeniz gerekir, örneğin.
function get(name){
if(name=(new RegExp('[?&]'+encodeURIComponent(name)+'=([^&]*)')).exec(location.search))
return decodeURIComponent(name[1]);
}
sadece parametre olarak GET değişken adı olan işlevi çağırın, örn.
get('foo');
bu işlev, değişkenin değeri yoksa veya yoksa tanımsız değişken değerini veya tanımsız döndürür
Bunu jquery.urlbeğendim kullanabilirsin :
var xyz = jQuery.url.param("param_in_url");
Güncellenen Kaynak: https://github.com/allmarkedup/jQuery-URL-Parser
var xyz = jQuery.url().param("param_in_url");jQuery.url()geçerli sayfa URL'sini veren doğru sözdizimidir . Lütfen düzeltmeyi yapın.
Sadece iki sentimi koymak için, tüm istekleri içeren bir nesne istiyorsanız
function getRequests() {
var s1 = location.search.substring(1, location.search.length).split('&'),
r = {}, s2, i;
for (i = 0; i < s1.length; i += 1) {
s2 = s1[i].split('=');
r[decodeURIComponent(s2[0]).toLowerCase()] = decodeURIComponent(s2[1]);
}
return r;
};
var QueryString = getRequests();
//if url === "index.html?test1=t1&test2=t2&test3=t3"
console.log(QueryString["test1"]); //logs t1
console.log(QueryString["test2"]); //logs t2
console.log(QueryString["test3"]); //logs t3
Unutmayın, her get parametresi için anahtar küçük harfe ayarlanmıştır. Bu yüzden yardımcı bir işlev yaptım. Yani şimdi büyük / küçük harfe duyarlı değil.
function Request(name){
return QueryString[name.toLowerCase()];
}
Aşağıdaki kodu deneyin, GET parametrelerini url'den almanıza yardımcı olacaktır. daha fazla ayrıntı için.
var url_string = window.location.href; // www.test.com?filename=test
var url = new URL(url_string);
var paramValue = url.searchParams.get("filename");
alert(paramValue)
Bugün ben biraz ile birlikte aşağıdaki koymak bu yüzden bir ilişkisel dizi haline sayfanın isteği parametrelerini almak için gereken yardımı dan benim arkadaşlar . Ayrıca bir =as olmadan parametreleri de işler true.
Bir örnekle:
// URL: http://www.example.com/test.php?abc=123&def&xyz=&something%20else
var _GET = (function() {
var _get = {};
var re = /[?&]([^=&]+)(=?)([^&]*)/g;
while (m = re.exec(location.search))
_get[decodeURIComponent(m[1])] = (m[2] == '=' ? decodeURIComponent(m[3]) : true);
return _get;
})();
console.log(_GET);
> Object {abc: "123", def: true, xyz: "", something else: true}
console.log(_GET['something else']);
> true
console.log(_GET.abc);
> 123
GET parametrelerini elde etmek için mevcut sayfanın URL'sini ayrıştırabilirsiniz. URL kullanılarak bulunabilir location.href.
Zaten jquery kullanıyorsanız, bunu işleyen bir jquery eklentisi vardır:
Harita küçültme çözümü:
var urlParams = location.search.split(/[?&]/).slice(1).map(function(paramPair) {
return paramPair.split(/=(.+)?/).slice(0, 2);
}).reduce(function (obj, pairArray) {
obj[pairArray[0]] = pairArray[1];
return obj;
}, {});
Kullanım:
For url: http://example.com?one=1&two=2
console.log(urlParams.one) // 1
console.log(urlParams.two) // 2
map/reducesadece bir koleksiyon işleme mekanizmasıdır: her boyuttaki veriyle kullanılabilir. paralelleştirme istekliliği nedeniyle büyük verilerle daha ünlüdür
Diğer yanıtların aksine, UrlSearchParamsnesne Regexes veya diğer dize manipülasyonlarını kullanmaktan kaçınabilir ve çoğu modern tarayıcıda mevcuttur:
var queryString = location.search
let params = new URLSearchParams(queryString)
// example of retrieving 'id' parameter
let id = parseInt(params.get("id"))
console.log(id)
Buradaki işlev parametreyi ada göre döndürür. Küçük değişikliklerle temel url, parametre veya çapa döndürebileceksiniz.
function getUrlParameter(name) {
var urlOld = window.location.href.split('?');
urlOld[1] = urlOld[1] || '';
var urlBase = urlOld[0];
var urlQuery = urlOld[1].split('#');
urlQuery[1] = urlQuery[1] || '';
var parametersString = urlQuery[0].split('&');
if (parametersString.length === 1 && parametersString[0] === '') {
parametersString = [];
}
// console.log(parametersString);
var anchor = urlQuery[1] || '';
var urlParameters = {};
jQuery.each(parametersString, function (idx, parameterString) {
paramName = parameterString.split('=')[0];
paramValue = parameterString.split('=')[1];
urlParameters[paramName] = paramValue;
});
return urlParameters[name];
}
Benim için çalışıyor
url: http: // localhost: 8080 / # /? access_token = 111
function get(name){
const parts = window.location.href.split('?');
if (parts.length > 1) {
name = encodeURIComponent(name);
const params = parts[1].split('&');
const found = params.filter(el => (el.split('=')[0] === name) && el);
if (found.length) return decodeURIComponent(found[0].split('=')[1]);
}
}