使用js獲取QueryString的方法小結(jié)
更新時間:2010年02月28日 08:07:13 作者:
從網(wǎng)上看到一些使用js獲取QueryString的方法,但用起來不是很理想,所以決定自己寫一個。主要原理是使用正則表達式匹配location.search中的字符串。
本文原理是使用正則表達式匹配location.search中的字符串。其中三個主要函數(shù)為 getQueryString()、getQueryStringByName(name)和getQueryStringByIndex(index)
//獲取QueryString的數(shù)組
function getQueryString(){
var result = location.search.match(new RegExp("[\?\&][^\?\&]+=[^\?\&]+","g"));
for(var i = 0; i < result.length; i++){
result[i] = result[i].substring(1);
}
return result;
}
//根據(jù)QueryString參數(shù)名稱獲取值
function getQueryStringByName(name){
var result = location.search.match(new RegExp("[\?\&]" + name+ "=([^\&]+)","i"));
if(result == null || result.length < 1){
return "";
}
return result[1];
}
//根據(jù)QueryString參數(shù)索引獲取值
function getQueryStringByIndex(index){
if(index == null){
return "";
}
var queryStringList = getQueryString();
if (index >= queryStringList.length){
return "";
}
var result = queryStringList[index];
var startIndex = result.indexOf("=") + 1;
result = result.substring(startIndex);
return result;
}
測試頁面路徑:QueryStringDemo.html?id=5&type=1&flag=0
頁面加載時:

在QueryString's name后的文本框中輸入要獲取的QueryString的名稱獲取相應(yīng)的值:

在QueryString's index后的文本框中輸入要獲取的QueryString的索引獲取相應(yīng)的值(索引從0開始):

這樣就可以在頁面中方便的獲取QueryString的值了。最后附上測試頁面QueryStringDemo.html的源代碼:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta content="text/html; charset=gb2312" http-equiv="Content-Type" />
<title>QueryString獲取演示代碼 www.dbjr.com.cn</title>
<script type="text/javascript">
//獲取QueryString的數(shù)組
function getQueryString(){
var result = location.search.match(new RegExp("[\?\&][^\?\&]+=[^\?\&]+","g"));
for(var i = 0; i < result.length; i++){
result[i] = result[i].substring(1);
}
return result;
}
//根據(jù)QueryString參數(shù)名稱獲取值
function getQueryStringByName(name){
var result = location.search.match(new RegExp("[\?\&]" + name+ "=([^\&]+)","i"));
if(result == null || result.length < 1){
return "";
}
return result[1];
}
//根據(jù)QueryString參數(shù)索引獲取值
function getQueryStringByIndex(index){
if(index == null){
return "";
}
var queryStringList = getQueryString();
if (index >= queryStringList.length){
return "";
}
var result = queryStringList[index];
var startIndex = result.indexOf("=") + 1;
result = result.substring(startIndex);
return result;
}
//綁定當控件高亮選中時,點擊“回車鍵”時執(zhí)行的操作
//control:要綁定事件的控件
//func:要執(zhí)行的方法
function bindEnterEvent(control, func){
control.onkeypress = function(){
if (event.keyCode == 13){
func();
}
}
}
//根據(jù)輸入的QueryString名稱獲取值
function getByName(){
var name = document.getElementById("txtQueryStringName").value;
document.getElementById("txtResult").innerHTML = getQueryStringByName(name);
}
//根據(jù)輸入的QueryString的索引獲取值
function getByIndex(){
var index = document.getElementById("txtQueryStringIndex").value;
document.getElementById("txtResult").innerHTML = getQueryStringByIndex(index);
}
</script>
</head>
<body>
<div>
<span>QueryString : </span><span id="queryString"></span>
</div>
<div>
<span>QueryString's name : </span>
<input id="txtQueryStringName" name="txtQueryStringName" type="text" />
<input name="btnGetByName" type="button" value="獲取" onclick="getByName()" />
</div>
<div>
<span>QueryString's index : </span>
<input id="txtQueryStringIndex" name="txtQueryStringIndex" type="text" />
<input name="btnGetByIndex" type="button" value="獲取" onclick="getByIndex()" />
</div>
<div>
<span>結(jié)果 :</span><span id="txtResult"></span>
</div>
<!--頁面加載時執(zhí)行的操作-->
<script type="text/javascript">
//顯示所有QueryString
document.getElementById("queryString").innerHTML = getQueryString();
//為txtQueryStringName綁定回車事件
bindEnterEvent(txtQueryStringName, getByName);
//為txtQueryStringIndex綁定回車事件
bindEnterEvent(txtQueryStringIndex, getByIndex);
</script>
</body>
</html>
pdf版下載地址
三個主要方法:
方法 |
說明 |
getQueryString |
獲取QueryString的數(shù)組。 例如路徑QueryStringDemo.html?id=5&type=1&flag=0 調(diào)用后返回["id=5", "type=1", "flag=0"] |
getQueryStringByName |
根據(jù)QueryString參數(shù)名稱獲取值 |
getQueryStringByIndex |
根據(jù)QueryString參數(shù)索引獲取值 |
復(fù)制代碼 代碼如下:
//獲取QueryString的數(shù)組
function getQueryString(){
var result = location.search.match(new RegExp("[\?\&][^\?\&]+=[^\?\&]+","g"));
for(var i = 0; i < result.length; i++){
result[i] = result[i].substring(1);
}
return result;
}
//根據(jù)QueryString參數(shù)名稱獲取值
function getQueryStringByName(name){
var result = location.search.match(new RegExp("[\?\&]" + name+ "=([^\&]+)","i"));
if(result == null || result.length < 1){
return "";
}
return result[1];
}
//根據(jù)QueryString參數(shù)索引獲取值
function getQueryStringByIndex(index){
if(index == null){
return "";
}
var queryStringList = getQueryString();
if (index >= queryStringList.length){
return "";
}
var result = queryStringList[index];
var startIndex = result.indexOf("=") + 1;
result = result.substring(startIndex);
return result;
}
測試頁面路徑:QueryStringDemo.html?id=5&type=1&flag=0
頁面加載時:

在QueryString's name后的文本框中輸入要獲取的QueryString的名稱獲取相應(yīng)的值:

在QueryString's index后的文本框中輸入要獲取的QueryString的索引獲取相應(yīng)的值(索引從0開始):

這樣就可以在頁面中方便的獲取QueryString的值了。最后附上測試頁面QueryStringDemo.html的源代碼:
復(fù)制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta content="text/html; charset=gb2312" http-equiv="Content-Type" />
<title>QueryString獲取演示代碼 www.dbjr.com.cn</title>
<script type="text/javascript">
//獲取QueryString的數(shù)組
function getQueryString(){
var result = location.search.match(new RegExp("[\?\&][^\?\&]+=[^\?\&]+","g"));
for(var i = 0; i < result.length; i++){
result[i] = result[i].substring(1);
}
return result;
}
//根據(jù)QueryString參數(shù)名稱獲取值
function getQueryStringByName(name){
var result = location.search.match(new RegExp("[\?\&]" + name+ "=([^\&]+)","i"));
if(result == null || result.length < 1){
return "";
}
return result[1];
}
//根據(jù)QueryString參數(shù)索引獲取值
function getQueryStringByIndex(index){
if(index == null){
return "";
}
var queryStringList = getQueryString();
if (index >= queryStringList.length){
return "";
}
var result = queryStringList[index];
var startIndex = result.indexOf("=") + 1;
result = result.substring(startIndex);
return result;
}
//綁定當控件高亮選中時,點擊“回車鍵”時執(zhí)行的操作
//control:要綁定事件的控件
//func:要執(zhí)行的方法
function bindEnterEvent(control, func){
control.onkeypress = function(){
if (event.keyCode == 13){
func();
}
}
}
//根據(jù)輸入的QueryString名稱獲取值
function getByName(){
var name = document.getElementById("txtQueryStringName").value;
document.getElementById("txtResult").innerHTML = getQueryStringByName(name);
}
//根據(jù)輸入的QueryString的索引獲取值
function getByIndex(){
var index = document.getElementById("txtQueryStringIndex").value;
document.getElementById("txtResult").innerHTML = getQueryStringByIndex(index);
}
</script>
</head>
<body>
<div>
<span>QueryString : </span><span id="queryString"></span>
</div>
<div>
<span>QueryString's name : </span>
<input id="txtQueryStringName" name="txtQueryStringName" type="text" />
<input name="btnGetByName" type="button" value="獲取" onclick="getByName()" />
</div>
<div>
<span>QueryString's index : </span>
<input id="txtQueryStringIndex" name="txtQueryStringIndex" type="text" />
<input name="btnGetByIndex" type="button" value="獲取" onclick="getByIndex()" />
</div>
<div>
<span>結(jié)果 :</span><span id="txtResult"></span>
</div>
<!--頁面加載時執(zhí)行的操作-->
<script type="text/javascript">
//顯示所有QueryString
document.getElementById("queryString").innerHTML = getQueryString();
//為txtQueryStringName綁定回車事件
bindEnterEvent(txtQueryStringName, getByName);
//為txtQueryStringIndex綁定回車事件
bindEnterEvent(txtQueryStringIndex, getByIndex);
</script>
</body>
</html>
pdf版下載地址
您可能感興趣的文章:
- JS獲取URL中參數(shù)值(QueryString)的4種方法分享
- js獲取URL的參數(shù)的方法(getQueryString)示例
- node.js中的querystring.parse方法使用說明
- node.js中的querystring.stringify方法使用說明
- JavaScript實現(xiàn)QueryString獲取GET參數(shù)的方法
- NodeJS學(xué)習筆記之(Url,QueryString,Path)模塊
- JavaScript QueryString解析類代碼
- node.js中的querystring.escape方法使用說明
- node.js中的querystring.unescape方法使用說明
- JavaScript獲取URL中參數(shù)querystring的方法詳解
相關(guān)文章
javascript小數(shù)計算出現(xiàn)近似值的解決辦法
在javascript里面,小數(shù)只能進行相似計算,例如:5.06+1.30,你得到的結(jié)果會是6.359999999999999,但有的小數(shù)計算又是正確的,如果計算出現(xiàn)了近似值,你可以用如下的方法計算。2010-02-02實現(xiàn)非常簡單的js雙向數(shù)據(jù)綁定
Angular實現(xiàn)了雙向綁定機制。所謂的雙向綁定,無非是從界面的操作能實時反映到數(shù)據(jù),數(shù)據(jù)的變更能實時展現(xiàn)到界面。本文給大家詳細介紹js雙向數(shù)據(jù)綁定,感興趣的朋友參考下2015-11-11