QueryString Javascript collection object, способный обрабатывать массивы - PullRequest
1 голос
/ 01 марта 2012

Мне нужно взять строку запроса (пример: ?name=value1&type=value2&name=value3&type=value4..., но этот код должен обрабатывать любую переданную ей строку запроса) и создать из нее объект.

Я почти завершил функцию, которая делает это. Тем не менее, моя логика немного внутри этого последнего цикла for. Если кто-то может указать, где я ошибся, я действительно ценю это!

Сначала я беру строку запроса с помощью функции jQuery $.get:

$.get("xmlreader.php", function(data) { 

    var queryParams = [];

    var qString = data;

    // test qString for & at the end
    var last = qString.lastIndexOf("&");
    if(last == qString.length - 1) {
        // then there is a & to remove
        qString = qString.substring(0,qString.length-1);
    }

    getParamObj(qString);

});

(я знаю, что это странно, что я удаляю последнее и здесь в моем JavaScript, но я не хочу на этом фокусироваться).

Затем я вызываю getParamObject(qString);, чтобы построить фактический объект коллекции:

function getParamObj(parameterString) {

var qString = parameterString;
var parameters = qString.split("&");
parameters[0] = parameters[0].substring(1);

var paramObject = new Object();

for(var index = 0; index < parameters.length; ++index) {
    var equalsPos = parameters[index].indexOf("=");
    var key = parameters[index].substring(0,equalsPos);

    var stringLength = parameters[index].length;

    var value = parameters[index].substring(equalsPos + 1, stringLength);

    if(!paramObject[key]) {
        console.log("paramObject[key] = " + paramObject[key]);
        paramObject[key] = value;
        if(paramObject[key] instanceof Array ) {
            console.log("instance of array");
            paramObject[key].push(value);
        }  else {
            var newArray = [];
            var existingValue = paramObject[key];
            console.log("existing value: " + existingValue);
            console.log("value: " + value);
            newArray.push(existingValue);
            newArray.push(value);
            paramObject[key] = newArray;
        }   

    }

}

Функция работает почти все правильно. Когда я проверяю это, пара вещей ошибочна: в последнем случае условное существующее значение и значение совпадают. Могут быть и другие проблемы, но я думаю, что это основная проблема.

Я видел подходы, использующие регулярные выражения, но я не хочу идти по этому пути здесь.

Примечание: я ответил на свой собственный вопрос. LOL ... стек не позволит мне это прокомментировать, потому что я недостаточно крутой, всего лишь с 58 представителями :)

[code]
if(!paramObject[key]) {
    console.log("paramObject[key] = " + paramObject[key]);
    paramObject[key] = value; 
    console.log("paramObject[key] = value = " + value + paramObject[key]);
    console.log(paramObject[key]);
    }
    else if(paramObject[key] instanceof Array ) {
    paramObject[key].push(value);
    console.log("value if arra" + value);
    }  else {
    var newArray = [];
    var existingValue = paramObject[key];
    console.log("existing value: " + existingValue);
    console.log("value: " + value);
    newArray.push(existingValue);
    newArray.push(value);
    paramObject[key] = newArray;
    }
[/code] 

1 Ответ

2 голосов
/ 01 марта 2012

Хотя вы говорите, что вам не нужна реализация на основе регулярных выражений, я подумал, что было бы полезно показать, как это может выглядеть:

params = {}
queryString.replace(/([^&=]+)=([^&=]*)/g, function($0, $1, $2) {
    (params[$1] = params[$1] || []).push($2);
});
// that's basically all about this

(не отвечает на вопрос, следовательно, CW).

...