Как читать GET-данные с URL с помощью JavaScript? - PullRequest
39 голосов
/ 02 мая 2009

Я пытаюсь передать данные с одной страницы на другую.

www.mints.com? Имя = что-то

Как читать name с помощью JavaScript?

Ответы [ 8 ]

56 голосов
/ 02 мая 2009
function parseURLParams(url) {
    var queryStart = url.indexOf("?") + 1,
        queryEnd   = url.indexOf("#") + 1 || url.length + 1,
        query = url.slice(queryStart, queryEnd - 1),
        pairs = query.replace(/\+/g, " ").split("&"),
        parms = {}, i, n, v, nv;

    if (query === url || query === "") return;

    for (i = 0; i < pairs.length; i++) {
        nv = pairs[i].split("=", 2);
        n = decodeURIComponent(nv[0]);
        v = decodeURIComponent(nv[1]);

        if (!parms.hasOwnProperty(n)) parms[n] = [];
        parms[n].push(nv.length === 2 ? v : null);
    }
    return parms;
}

Использовать следующим образом:

var urlString = "http://www.foo.com/bar?a=a+a&b%20b=b&c=1&c=2&d#hash";
    urlParams = parseURLParams(urlString);

, который возвращает объект, подобный этому:

{
  "a"  : ["a a"],     /* param values are always returned as arrays */
  "b b": ["b"],       /* param names can have special chars as well */
  "c"  : ["1", "2"]   /* an URL param can occur multiple times!     */
  "d"  : [null]       /* parameters without values are set to null  */ 
} 

So

parseURLParams("www.mints.com?name=something")

дает

{name: ["something"]}

РЕДАКТИРОВАТЬ : оригинальная версия этого ответа использовала основанный на регулярных выражениях подход к парсингу URL. В нем использовалась более короткая функция, но подход был ошибочным, и я заменил его соответствующим синтаксическим анализатором.

6 голосов
/ 13 октября 2009

Я думаю, это также должно работать:

function $_GET(q,s) {
    s = (s) ? s : window.location.search;
    var re = new RegExp('&amp;'+q+'=([^&amp;]*)','i');
    return (s=s.replace(/^\?/,'&amp;').match(re)) ?s=s[1] :s='';
}

Просто назовите это так:

var value = $_GET('myvariable');
3 голосов
/ 08 апреля 2019

Это 2019 год, и нет необходимости в каком-либо рукописном решении или сторонней библиотеке. Если вы хотите проанализировать URL текущей страницы в браузере:

# running on https://www.example.com?name=n1&name=n2
let params = new URLSearchParams(location.search);
params.get('name') # => "n1"
params.getAll('name') # => ["n1", "n2"]

Если вы хотите проанализировать случайный URL, либо в браузере, либо в Node.js:

let url = 'https://www.example.com?name=n1&name=n2';
let params = (new URL(url)).searchParams;
params.get('name') # => "n1"
params.getAll('name') # => ["n1", "n2"]

Используется интерфейс URLSearchParams , который поставляется с современными браузерами.

3 голосов
/ 02 мая 2009

Вот одно из решений. Конечно, эту функцию не нужно загружать в опцию «window.params» - ее можно настроить.

window.params = function(){
    var params = {};
    var param_array = window.location.href.split('?')[1].split('&');
    for(var i in param_array){
        x = param_array[i].split('=');
        params[x[0]] = x[1];
    }
    return params;
}();

Пример вызова API на http://www.mints.com/myurl.html?name=something&goal=true:

if(window.params.name == 'something') doStuff();
else if( window.params.goal == 'true') shoutGOOOOOAAALLL();
3 голосов
/ 02 мая 2009

location.search https://developer.mozilla.org/en/DOM/window.location

хотя большинство использует какую-то процедуру синтаксического анализа для чтения параметров строки запроса.

вот один http://safalra.com/web-design/javascript/parsing-query-strings/

1 голос
/ 20 октября 2017

Выбранный в настоящее время ответ не работал вообще в моем случае, который я считаю довольно типичным. Я нашел ниже функцию здесь , и она прекрасно работает!

function getAllUrlParams(url) {

  // get query string from url (optional) or window
  var queryString = url ? url.split('?')[1] : window.location.search.slice(1);

  // we'll store the parameters here
  var obj = {};

  // if query string exists
  if (queryString) {

    // stuff after # is not part of query string, so get rid of it
    queryString = queryString.split('#')[0];

    // split our query string into its component parts
    var arr = queryString.split('&');

    for (var i=0; i<arr.length; i++) {
      // separate the keys and the values
      var a = arr[i].split('=');

      // in case params look like: list[]=thing1&list[]=thing2
      var paramNum = undefined;
      var paramName = a[0].replace(/\[\d*\]/, function(v) {
        paramNum = v.slice(1,-1);
        return '';
      });

      // set parameter value (use 'true' if empty)
      var paramValue = typeof(a[1])==='undefined' ? true : a[1];

      // (optional) keep case consistent
      paramName = paramName.toLowerCase();
      paramValue = paramValue.toLowerCase();

      // if parameter name already exists
      if (obj[paramName]) {
        // convert value to array (if still string)
        if (typeof obj[paramName] === 'string') {
          obj[paramName] = [obj[paramName]];
        }
        // if no array index number specified...
        if (typeof paramNum === 'undefined') {
          // put the value on the end of the array
          obj[paramName].push(paramValue);
        }
        // if array index number specified...
        else {
          // put the value at that index number
          obj[paramName][paramNum] = paramValue;
        }
      }
      // if param name doesn't exist yet, set it
      else {
        obj[paramName] = paramValue;
      }
    }
  }

  return obj;
}
1 голос
/ 29 августа 2012

Iv'e исправлен / улучшен ответ Томалака с:

  • Делайте массив только при необходимости.
  • Если в значении есть другой символ уравнения, он попадает внутрь значения
  • Теперь вместо URL указывается значение location.search.
  • Пустая строка поиска приводит к пустому объекту.

Код:

function getSearchObject() {
    if (location.search === "") return {};

    var o = {},
        nvPairs = location.search.substr(1).replace(/\+/g, " ").split("&");

    nvPairs.forEach( function (pair) {
        var e = pair.indexOf('=');
        var n = decodeURIComponent(e < 0 ? pair : pair.substr(0,e)),
            v = (e < 0 || e + 1 == pair.length) 
                ? null : 
                decodeURIComponent(pair.substr(e + 1,pair.length - e));
        if (!(n in o))
            o[n] = v;
        else if (o[n] instanceof Array)
            o[n].push(v);
        else
            o[n] = [o[n] , v];
    });
    return o;
}
0 голосов
/ 26 июля 2015

Я также сделал довольно простую функцию. Вы звоните по этому вопросу: получить ( "yourgetname");

и получите все, что было. (теперь, когда я написал это, я заметил, что это даст вам% 26, если у вас есть & в вашей ценности ..)

function get(name){
  var url = window.location.search;
  var num = url.search(name);
  var namel = name.length;
  var frontlength = namel+num+1; //length of everything before the value 
  var front = url.substring(0, frontlength);  
  url = url.replace(front, "");  
  num = url.search("&");

 if(num>=0) return url.substr(0,num); 
 if(num<0)  return url;             
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...