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)文章
js實(shí)現(xiàn)的光標(biāo)位置工具函數(shù)示例
這篇文章主要介紹了js實(shí)現(xiàn)的光標(biāo)位置工具函數(shù),結(jié)合實(shí)例形式分析了JavaScript操作textarea文本框光標(biāo)位置及文本操作相關(guān)技巧,需要的朋友可以參考下2016-10-10
淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別
這篇文章主要介紹了淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別,需要的朋友可以參考下2015-02-02
JavaScript學(xué)習(xí)小結(jié)(7)之JS RegExp
在js中,正則表達(dá)式是由一個(gè)RegExp對(duì)象表示的,RegExp 是正則表達(dá)式的縮寫。RegExp簡(jiǎn)單的模式可以是一個(gè)單獨(dú)的字符。更復(fù)雜的模式包括了更多的字符,并可用于解析、格式檢查、替換等等??梢允褂靡粋€(gè)RegExp()構(gòu)造函數(shù)來創(chuàng)建RegExp對(duì)象,也可以使用直接量語法2015-11-11
webpack學(xué)習(xí)教程之publicPath路徑問題詳解
這篇文章主要給大家介紹了webpack學(xué)習(xí)教程之publicPath路徑問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-06-06
javascript下搜索子字符串的的實(shí)現(xiàn)代碼(腳本之家修正版)
由于我的項(xiàng)目中要求到要對(duì)一個(gè)字符串進(jìn)行查找,其查找要求有點(diǎn)BT了2009-12-12
js獲取當(dāng)前頁的URL與window.location.href簡(jiǎn)單方法
下面小編就為大家?guī)硪黄猨s獲取當(dāng)前頁的URL與window.location.href簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
JavaScript純前端實(shí)現(xiàn)在線GIF壓縮
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript純前端實(shí)現(xiàn)在線GIF壓縮工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03

