当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js中url对象化管理分析

js中url对象化管理分析

2018年02月05日  | 移动技术网IT编程  | 我要评论

1.问题描述

url是web编写过程中一种不可或缺的需要打交道的值,不论是在页面跳转中,还是ajax请求数据或是其他框架插件的url提供.
对于很多程序猿来说,js中经常遇到需要变更url(主要是其中所包含的参数)的情况,大多数人使用的方法是直接拼接.
这种方法胜在简单,同样存在不少不足,如:

拼接形成的url安全性上总是存在潜在的危险;

从某个完整url中获取其中所包含的参数和纯地址,以进行下一步的比较,也是件较麻烦的事情;

2.解决思路

基于以上问题,我的解决策略是将url进行对象化的管理,将url纯地址,url参数分别放到一个对象的各个属性中.
每次对url的变更,可使用先分析为对象格式,再变更其中某些参数,再组建成为新的url方法.
这样构建再开始做的时候也许会觉得有些多此一举,但在处理一些比较复杂的情况时,会非常方便.

3.演示代码

首先提供分析和组建url的方法(可以考虑将之封装成一个方法,方法称的话可以起的再复杂些以避免重复):

/**
 * 数据处理-解析url为一个对象
 */
function parseurl(strurl){
	var arrurlpart=strurl.split('?');
	var strurl=arrurlpart[0];
	var murl={
		url:strurl
	};
	if(arrurlpart.length===2){
		var strparam=arrurlpart[1];
		var arrparampart=strparam.split('&');
		for(i in arrparampart){
			var strparampart=arrparampart[i];
			var arrparamky=strparampart.split('=');
			var strkey=arrparamky[0];
			var strvalue=decodeuricomponent(arrparamky[1]);
			murl[strkey]=strvalue;
		}
	}
	return murl;
}
/**
 * 数据处理-构成/组建url(字符串)
 */
function concaturl(murl){
	var strurl=murl.url;
	var strparam='';
	for(strkey in murl){
		if(strkey==='url'||murl[strkey]===null)
			continue;
		strparam+=(strkey+'='+encodeuricomponent(murl[strkey])+'&');//注入避免
	}
	if(strparam!==''){
		strparam=('?'+strparam.substring(0,strparam.length-1));
	}
	return strurl+strparam;
}

以下是用法示例,当然仅展示了比较简单的情况,可能不能完全体现url对象化管理的威力:

var strurl1='www.example.com/admin/product/main?group_code=test_group&p_code=shangpin1';
var murl1=parseurl(strurl1);
console.log(murl1.p_code);
murl1.p_code='shangpin2';
var strurl2=concaturl(murl1);
console.log(strurl2);
murl1.group_code=null;
murl1.user_name='用?&=户';
var strurl3=concaturl(murl1);
console.log(strurl3);
var murl3=parseurl(strurl3);
console.log(murl3.user_name);

打印结果为:

shangpin1
www.example.com/admin/product/main?group_code=test_group&p_code=shangpin2
www.example.com/admin/product/main?p_code=shangpin2&user_name=%e7%94%a8%3f%26%3d%e6%88%b7
用?&=户

以上情况,特别是情况3,可以说将url转换功能使用的非常灵活了.

当然实际在使用的时候,为安全起见,产生一个新的url通常会先创建一个新的对象,而非在原有对象基础上修改.

4.待改进的地方

以上情况适用于非路径参数的情况下,当使用路径参数时,如:

www.example.com/admin/product/list/1

这个1作为参数,在该方法就不适用了.

也可以优化方法,将方法转化为适用于路径参数的解析与重构,这又是后话了。

以上就是我们给大家详细介绍的关于js中url对象化管理的全部内容,感谢你对移动技术网的支持。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网