JavaScript重定向URL參數(shù)的兩種方法小結(jié)
這篇文章主要介紹的是JavaScript重定向URL參數(shù)的兩種方法,下面話不多說,直接看示例代碼。
一、字符拼接形式
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); //獲取參數(shù) if (strUrl.toLowerCase().indexOf(para.toLowerCase()) == -1) { //如果沒有找到參數(shù),則直接賦值 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)) { //有需要的參數(shù)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; }
調(diào)用:
<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="重定義參數(shù)" />
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關文章
js中substr,substring,indexOf,lastIndexOf,split,replace的用法詳解
這篇文章主要介紹了js中substr,substring,indexOf,lastIndexOf,split,replace的用法詳解的相關資料,需要的朋友可以參考下2015-11-11利用window.name實現(xiàn)windowStorage代碼分享
本文主要介紹了利用window.name實現(xiàn)windowStorage的功能分享,大家參考使用吧2014-01-01ES6 新增的創(chuàng)建數(shù)組的方法(小結(jié))
這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08js基于setTimeout與setInterval實現(xiàn)多線程
這篇文章主要介紹了js基于setTimeout與setInterval實現(xiàn)多線程的方法,分析了多線程的原理與javascript模擬實現(xiàn)多線程的相關技巧,需要的朋友可以參考下2016-06-06原生JS實現(xiàn)H5轉(zhuǎn)盤游戲的示例代碼
這篇文章主要介紹了如何利用原生JS實現(xiàn)轉(zhuǎn)盤游戲,可以自由調(diào)整概率。文中的示例代碼講解詳細,對我們學習JavaScript有一定幫助,需要的可以參考一下2022-03-03