JavaScript重定向URL参数的两种方法小结
2016-10-19 09:07
1056 查看
这篇文章主要介绍的是JavaScript重定向URL参数的两种方法,下面话不多说,直接看示例代码。
一、字符拼接形式
function setUri(para, val) { var strNewUrl = new String(); var strUrl = new String(); var url = window.location.href; strUrl = window.location.href; if (strUrl.indexOf("?") != -1) { strUrl = strUrl.substr(strUrl.indexOf("?") + 1); //获取参数 if (strUrl.toLowerCase().indexOf(para.toLowerCase()) == -1) { //如果没有找到参数,则直接赋值 strNewUrl = url + "&" + para + "=" + val; window.location.href = strNewUrl; } else { var aParam = strUrl.split("&"); for (var i = 0; i < aParam.length; i++) { if (aParam[i].substr(0, aParam[i].indexOf("=")).toLowerCase() == para.toLowerCase()) { aParam[i] = aParam[i].substr(0, aParam[i].indexOf("=")) + "=" + val; } } strNewUrl = url.substr(0, url.indexOf("?") + 1) + aParam.join("&"); window.location.href = strNewUrl; } } else { strUrl += "?" + para + "=" + val; window.location.href = strUrl; } }
二、利用正则
//使用正则 function setPara(para, val) { var newpar = ""; var url = window.location.href; var pars = location.search.substring(1); var reg = new RegExp("(^|)" + para + "=([^&]*)(|$)"); if (reg.test(pars)) { //有需要的参数para var p1 = pars.split(para)[0]; //productID=100857&count=1& var p2 = pars.split(para)[1]; //=75825&coupval=1.5&addressID=358&invoiceID=1245&invoiceName=jesse if (p2.indexOf("&") > -1) { var p3 = p2.split("&")[0]; if (p3 == "=" + val + "") { return false; } newpar = p1 + para + '=' + val + '&' + (p2.split(p3))[1]; } else { if (p1) { newpar = p1 + para + '=' + val; } else { newpar = para + '=' + val; } } } else { if (url.indexOf("?") == -1) { newpar = pars +"&"+ para + "=" + val; } else { newpar = pars + "&" + para + "=" + val; } } window.location.href = location.href.split('?')[0] + "?" + newpar; }
调用:
<script> window.onload = function () { var btn = document.getElementById("btnClick"); btn.onclick = function () { // url地址:http://localhost:54714/testuri.aspx?productID=100857&count=1&coupresId=12785&coupval=1.5&openId=12456&addressID=358&invoiceID=&invoiceName= //setUri("coupresId", 0); setPara("coupresId", 0); } } </script> <input type="button" id="btnClick" value="重定义参数" />
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
您可能感兴趣的文章:
相关文章推荐
- 使用JavaScript获取URL中的参数(两种方法)
- 使用JavaScript获取URL中的参数(两种方法)
- javascript 获取当前 URL 参数的两种方法:
- 使用JavaScript获取URL中的参数(两种方法)
- javascript 获取当前 URL 参数的两种方法:
- Javascript 获取链接(url)参数的方法[正则与截取字符串]
- JAVASCRIPT用Url传递参数出现中文乱码的解决方法
- Javascript 获取链接(url)参数的方法
- (收藏备用)两个Javascript方法,取url中的参数字符串
- Javascript用Url传递参数出现中文乱码的解决方法
- Javascript 获取链接(url)参数的方法
- javascript获取当前url网址及其参数方法总结
- Javascript获取URL参数的两种方式
- 用javascript获得地址栏参数的两种方法
- javascript通过url向jsp页面传递中文参数乱码解决方法
- Javascript 获取链接(url)参数的方法
- Javascript 调用C# 代码并传递参数的两种方法
- Javascript 获取链接(url)参数的方法
- Javascript获取url参数(queryString)一个比较简洁的方法
- Javascript 获取链接(url)参数的方法