如何使用jQuery BBQ插件没有值的参数?

时间:2011-11-05 16:04:12

标签: jquery jquery-bbq

我需要定义和读取哈希值,如

#page1&filter=1-1-0 
#filter=1-1-0 (if page number is omitted)
#page1 (if filter is not defined)

即。页码将是参数的一部分,并且没有值。 如何使用这些参数工作(获取和设置)?

2 个答案:

答案 0 :(得分:2)

您可以使用window.location.hash访问URL中的哈希值后的字符串内容。

然后,您需要进行一些解析才能获得键值对。类似下面的代码:

function getParameters(){
    params = {}
    var keyValuePairs = window.location.hash.substr(1).split('&');
    for (x in keyValuePairs){
        var split = keyValuePairs[x].split('=', 2);
        params[split[0]] = (split[1]) ? decodeURI(split[1]) : "";
    }
    return params;
}

function setParameters(key, value){
    var params = getParameters();
    params[key] = value;
    var hashString = ""
    for (x in params){
        if (params[x]){
            hashString += "&" + x + "=" + encodeURI(params[x]);
        } else {
            hashString += "&" + x;
        }
    }
    window.location.hash = hashString.substr(1);
}

您可以通过以下方式阅读“过滤器”参数:

var parameters = getParameters();
console.log(parameters.filter);

答案 1 :(得分:0)

以下是使用BBQ插件的解决方案(demo):

var hash = $.deparam.fragment();
var page = 'page1';
$.each(hash, function(i, val) {
    if (i.indexOf('page') != -1) page = i;
});
var filter = (hash.filter==undefined) ? '0-0-0' : hash.filter;

// update hash
$.bbq.pushState('#' + page + '&filter=' + filter);