url处理函数集合

function URL(name){
	if(typeof name=="undefined"){
	throw new Error("你需要传入一个url作为参数");
	}
	this.name=name;
}

URL.prototype={
	constructor:URL,

	addArg:function(key,value){
	if(this.name.indexOf("?")==-1)
	{
		this.name+="?";
	}else{
		this.name+="&";
	}
	this.name+=encodeURIComponent(key)+"="+
		encodeURIComponent(value);
	return this.url;
	},

	//URL 参数查询
	getQueryString:function(key){
		var reg = new RegExp("(^|&)"+ key +"=([^&]*)(&|$)");
     	var r = this.getSearchString().substr(1).match(reg);
     	if(r!=null)return  unescape(r[2]); return null;
	},
	//返回URL查询字符串
	getSearchString:function(){
		var mark=this.name.indexOf("?");
		if(mark!=-1){
			return decodeURIComponent(this.name.substr(mark));
		}else
		{
			return "";
		}
	}
}

使用方法

addArg(key,value)     添加参数       key-value 表示要添加参数的键值对

getQueryString(key)   获得key参数值  

getSearchString()   获得 所有参数字符串,包括“?”  


下面是一个简单的小例子:

var url=new URL("http://www.baidu.com");
console.log(url.name);        //http://www.baidu.com
url.addArg("message","周六的天气真好")
console.log(url.name);//http://www.baidu.com?message=%E5%91%A8%E5%85%AD%E7%9A%84%E5%A4%A9%E6%B0%94%E7%9C%9F%E5%A5%BD
url.addArg("value","123467916")
console.log(url.name);//http://www.baidu.com?message=%E5%91%A8%E5%85%AD%E7%9A%84%E5%A4%A9%E6%B0%94%E7%9C%9F%E5%A5%BD&value=123467916
console.log(url.getQueryString("value"));//123456

以后有其他的需要再写


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值