JavaScript QueryString解析類代碼
更新時(shí)間:2010年01月17日 21:22:54 作者:
以前寫的一個(gè)解析QueryString的JS類,可以獲取或設(shè)置QueryString中的值,記下了方便找 :)
使用示例:
var qs = new QueryString(query);
qs.set("ajaxids", ids)
qs.set("ajaxsn", new Date())
query = qs.toStr();
也可以連續(xù)調(diào)用:
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;
};
};
復(fù)制代碼 代碼如下:
var qs = new QueryString(query);
qs.set("ajaxids", ids)
qs.set("ajaxsn", new Date())
query = qs.toStr();
也可以連續(xù)調(diào)用:
復(fù)制代碼 代碼如下:
query = new QueryString(query).set("ajaxids", ids).set("ajaxsn", new Date()).toStr();
其它用法就自己看代碼琢磨吧。
完整代碼:
復(fù)制代碼 代碼如下:
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;
};
};
您可能感興趣的文章:
- JS獲取URL中參數(shù)值(QueryString)的4種方法分享
- 使用js獲取QueryString的方法小結(jié)
- js獲取URL的參數(shù)的方法(getQueryString)示例
- node.js中的querystring.parse方法使用說明
- node.js中的querystring.stringify方法使用說明
- JavaScript實(shí)現(xiàn)QueryString獲取GET參數(shù)的方法
- NodeJS學(xué)習(xí)筆記之(Url,QueryString,Path)模塊
- node.js中的querystring.escape方法使用說明
- node.js中的querystring.unescape方法使用說明
- JavaScript獲取URL中參數(shù)querystring的方法詳解
相關(guān)文章
基于prototype擴(kuò)展的JavaScript常用函數(shù)庫
基于prototype擴(kuò)展的JavaScript常用函數(shù)庫實(shí)現(xiàn)代碼,學(xué)習(xí)js的朋友可以參考下。2010-11-11CocosCreator入門教程之網(wǎng)絡(luò)通信
這篇文章主要介紹了CocosCreator的網(wǎng)絡(luò)通信,內(nèi)容不多,涉及到的細(xì)節(jié),讀者可以根據(jù)實(shí)際情況,自己去延申2021-04-04javascript-簡單的計(jì)算器實(shí)現(xiàn)步驟分解(附圖)
輸入內(nèi)容的判斷,對于事件對象的來源的判斷以及數(shù)學(xué)運(yùn)算“+,-,*,/”的使用,感興趣的朋友可以學(xué)習(xí)下2013-05-05用Javascript 和 CSS 實(shí)現(xiàn)腳注(Footnote)效果
腳注(Footnote)是向用戶提供更多信息的一個(gè)最佳途徑,也是主體信息的一個(gè)有效補(bǔ)充,常見于各種印刷書籍中。2009-09-09原生js實(shí)現(xiàn)給指定元素的后面追加內(nèi)容
給指定元素的后面追加一些自己想要實(shí)現(xiàn)的效果或者是一些屬性之類的,有木有遇到過,接下來為大家詳細(xì)介紹下追加的實(shí)現(xiàn)代碼,感興趣的朋友可以參考下哈2013-04-04JS實(shí)現(xiàn)動(dòng)態(tài)給標(biāo)簽控件添加事件的方法示例
這篇文章主要介紹了JS實(shí)現(xiàn)動(dòng)態(tài)給標(biāo)簽控件添加事件的方法,結(jié)合實(shí)例形式分析了javascript簡單實(shí)現(xiàn)動(dòng)態(tài)添加事件的相關(guān)操作技巧,需要的朋友可以參考下2017-05-05