通过javascript获取get请求的参数

整个类的代码如下:

/**
* 获取get请求中的参数
*
* @author MaLong
* @param loc
* (可选String or Object) String 类型须为URL, Object则为Location的对象
* 默认为window.location
*/
var Request = function(loc) {
var paramsStr;
var hashSearchString;
if (!loc || typeof loc == "object") {
loc = loc || window.location;
if (/#.+\?/.test(paramsStr)) {
paramsStr = loc.hash;
} else
paramsStr = loc.search;
} else if (typeof loc == "string") {
if (/.*\?.+[#.+]?/.test(loc))
paramsStr = loc.replace(/.*\?/, "");
else
paramsStr = loc.replace(/.*#/, "#");
}
if (!/#.+\?/.test(paramsStr)) {
this.pageSelector = paramsStr.replace(/^\?.*#$/, "#");
hashSearchString = paramsStr.replace(/\?|(#.+)/, "");
} else {
this.pageSelector = paramsStr.replace(/\?.*$/, "");
hashSearchString = paramsStr.replace(/#.+\?/, "");
}
var params = hashSearchString.split("&");
var reg = /^(\w+)=(.*)$/;
this.paramsMap = {};
for ( var i = 0, length = params.length; i < length; i++) {
var _p = reg.exec(params[i]);
if (_p)
this.paramsMap[_p[1]] = _p[2];
}
}
Request.prototype = {
/**
* 根据参数名获取参数值
*
* @param name
* @return 参数值
*/
getParam : function(name) {
return this.paramsMap[name];
},
/**
* 设置参数名和参数值
*
* @param name
* 参数名
* @param value
* 参数值
*/
setParam : function(name, value) {
this.paramsMap[name] = value;
},
/**
* 获取所有参数
*
* @returns 封装所有参数名和参数值的json
*/
getParams : function() {
return this.paramsMap;
},
/**
*
*/
paramSize : function() {
},
/**
*
*/
getHashParam : function() {
},
/**
* pageSelector 为通过hash值改变页面而预留,例:xxx.com#pageSelector
*/
getPageSelector : function() {
return this.pageSelector;
}
}


调用:


if(!/.*\?.+/.test(dataUrl))
dataUrl=window.location;
//dataUrl 可选
var request = new Request(dataUrl);
var userName=request.getParam("userName");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值