程序员人生 网站导航

解析 QueryString 的 JavaScript 类

栏目:jscript时间:2013-11-24 12:27:38
以前写的一个解析QueryString的JS类,可以获取或设置QueryString中的值,记下了方便找 :)

使用示例:
var qs = new QueryString(query);

qs.set("ajaxids", ids)
qs.set("ajaxsn", new Date())

query = qs.toStr();

也可以连续调用:

query = new QueryString(query).set("ajaxids", ids).set("ajaxsn", new Date()).toStr();

其它用法就自己看代码琢磨吧。

完整代码:

QueryString = function(qs){
this.p={};

if(!qs)
url=location.search;

if(qs) {
var b = qs.indexOf('?');
var e = qs.indexOf('#');

if(b >= 0){
qs = e < 0 ? qs.substr(b + 1) : qs.substring(b + 1,e);

if(qs.length > 0){
qs = qs.replace(/+/g, ' ');

var a = qs.split('&');

for (var i = 0; i < a.length; i++) {
var t = a[i].split('=');
var n = decodeURIComponent(t[0]);
var v = (t.length == 2) ? decodeURIComponent(t[1]) : n;
this.p[n] = v;
}
}
}
}

this.set = function(name, value){
this.p[name] = value;
return this;
};

this.get = function(name, def){
var v = this.p[name];
return (v != null) ? v : def;
};

this.has = function(name) {
return this.p[name] != null;
};

this.toStr = function() {
var r='?';
for (var k in this.p) {
r += encodeURIComponent(k) + '=' + encodeURIComponent(this.p[k]) + '&';
}
return r;
};
};
------分隔线----------------------------
------分隔线----------------------------

最新技术推荐