格式化html源码正则,通过正则格式化url查询字符串实现代码

看到项目里通过js数组split方法格式化查询字符串的,突发奇想为什么不能用正则呢,性能如何?于是便有了如下代码:

var url='www.baidu.com?a=123&b=456&c=789&e=dfsdfsdfsdfsdfsdfsdf&f=46545454545454785&g=e23232dsfvdfvdf';

/**

* 格式化查询字符串(正则实现)

* @param url url地址

* @return {Object} 格式化的json对象

*/

function formatUrl(url){

var reg=/(?:[?&]+)([^&]+)=([^&]+)/g;

var data={};

function fn(str,pro,value){

data[decodeURIComponent(pro)]=decodeURIComponent(value);

}

url.replace(reg,fn);

return data;

}

/**

* 格式化查询字符串(数组实现)

* @param url url地址

* @return {Object} 格式化的json对象

*/

function formatUrl2(url){

url=url.replace(/.*\?/,'');

var args={},

items=url.length?url.split("&"):[]

,item=null

,i=0

,len=items.length;

for(i=0;i

item=items[i].split("=");

args[decodeURIComponent(item[0])]=decodeURIComponent(item[1]);

}

return args;

}

var startTime=new Date();

for(var i=0;i<1000000;i++){

formatUrl2(url);

}

console.log('formatUrl2',(new Date()-startTime)); //formatUrl2 12138

startTime=new Date();

for(var i=0;i<1000000;i++){

formatUrl(url);

}

console.log('formatUrl',(new Date()-startTime)); //formatUrl 12537

测试浏览器是chrme 25;正则实现的函数居然比数组实现的函数要慢(泪奔....)。不过还好,在重复执行一百万次的情况下只慢0.4秒

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值