问题是这样的,某个情况下要给:http://jb51.net?a=1
这类url地址追加参数变为:http://jb51.net?a=1b=2
但是怎么知道已经存在相同参数名呢,例如有这种情况:http://jb51.net?a=1a=2
这个虽然不会有什么大错误,但是地址栏这样看起来很不好。那怎么办呢?用正则解决吧(本来我想用php的字符串处理解决的,但是后来觉得要学一下正则了就用正则做吧)
以下是我用于返回上一页的后台处理方法
复制代码 代码如下:
function _goBack($msg=null,$get=array()) {
$url = $_SESSION['BACKURL'];
if($get!=array())
foreach ($get as $k=>$g){
$url.=''.$k.'='.$g;//先追加所有要追加的参数,不管是否重复
if(count(explode("{$k}=",$url))>2){//假如以"a="这种格式分割目前url字符串发现有超过两个的分割数组,即表明该字符串有重复参数
$url=preg_replace("/{$k}=[a-zA-Z0-9]*/",'',$url);//正则替换所有"a=x"为空
}
}
unset($_SESSION['BACKURL']);
$this->alert($msg,$url);
}
简单的解释:
“/{$k}=[a-zA-Z0-9]*/”假如我们假设$k=”a”,即”/a=[a-zA-Z0-9]*/”
不知道有没理解错,这个意思其实是匹配以"a="开头,紧跟任意数字字母组合([a-zA-Z0-9]*:意思是任意单个数字或者字母字符,可以把*理解为对前面那个任意字符的重复,如u*可以理解为:uuuu.....,不限制个数的u排列,这里的*可以用{0,}代替),再紧跟""。
这是个很简单的例子,但是看网上的关于正则语法的描述,总感觉看不明白,不知道是我理解能力问题还是写得人说得太深奥。
另外解释一下,为什么这样就可以去除重复,原理很简单,http://jb51.net?a=1a=2被替换”a=x”格式字符的时候最后一个正好不会被删除,要知道我们循环中每次我们都是把新参数放在最后面的。