方法一:
下面是javascrīpt的一種實現方法, 這個函數是經過window.location.href中的分割符得到各個參數。html
有了這個函數,就能夠在頁面之間傳遞參數了。java
/*
*函數功能:從href得到參數
*sHref: http://www.artfh.com/arg.htm?arg1=d&arg2=re
*sArgName:arg1, arg2
*return: the value of arg. d, re
*/
function GetArgsFromHref(sHref, sArgName)
{
var args = sHref.split("?");
var retval = "";
if(args[0] == sHref) /*參數爲空*/
{
return retval; /*無需作任何處理*/
}
var str = args[1];
args = str.split("&");
for(var i = 0; i < args.length; i ++)
{
str = args[i];
var arg = str.split("=");
if(arg.length <= 1) continue;
if(arg[0] == sArgName) retval = arg[1];
}
return retval;
}web
方法二:
html地址傳遞參數進行其餘事情.
<scrīpt>
/* 用途: 接收地直欄參數 取id=1 根據ID的值 */
urlinfo=window.location.href; //獲取當前頁面的url
len=urlinfo.length;//獲取url的長度
offset=urlinfo.indexOf("?");//設置參數字符串開始的位置
newsidinfo=urlinfo.substr(offset,len)//取出參數字符串 這裏會得到相似「id=1」這樣的字符串
newsids=newsidinfo.split("=");//對得到的參數字符串按照「=」進行分割
newsid=newsids[1];//獲得參數值
newsname=newsids[0];//獲得參數名字
</scrīpt>數組
方法三:
<SCRIPT LANGUAGE="JavaScript">
function getvalue(name){
var str=window.location.search; //location.search是從當前URL的?號開始的字符串 例如:http://www.51job.com/viewthread.jsp?tid=22720 它的search就是?jsp
tid=22720函數
if (str.indexOf(name)!=-1){
var pos_start=str.indexOf(name)+name.length+1;
var pos_end=str.indexOf("&",pos_start);
if (pos_end==-1){
alert( str.substring(pos_start));
}else{
alert("對不起這個值不存在!");
}
}this
</SCRIPT>url
方法四:
作中英轉換的時候,要準確的獲取參數並取出,因此作了一個簡單的html中用js獲取當取地址欄的一個Object。
裏面有三個方法:
一、request.QueryString("參數")//獲取指定參數,返回字符串;
二、request.QueryStrings();//獲取所有參數,並返回數組;
三、request.setQuery("參數","參數的值");//若是當前地址欄有此參數,那麼將更新此參數,不然返回一個新的地址欄參數字符串。
例如:
當前地址欄參數字符串爲:?name=a&site=never_online
alert(request.setQuery("name","blueDestiny"))
若是地址欄參數中有"name",那麼返回?name=blueDestiny&site=never_online
setQuery方法有自動追加參數的功能。如:
當前地址欄參數字符串爲:?site=never_online
alert(request.setQuery("name","blueDestiny"))
則返回?site=never_online&name=blueDestiny
同理,若是地址欄沒有參數,也會自動追加參數
alert(request.setQuery("name","blueDestiny"))
返回?name=blueDestiny
<SCRIPT LANGUAGE="JavaScript">
<!--
// author: never-online
// web: never-online.net
var request = {
QueryString : function(val) {
var uri = window.location.search;
var re = new RegExp("" +val+ "\=([^\&\?]*)", "ig");
return ((uri.match(re))?(uri.match(re)[0].substr(val.length+1)):null);
},
QueryStrings : function() {
var uri = window.location.search;
var re = /\w*\=([^\&\?]*)/ig;
var retval=[];
while ((arr = re.exec(uri)) != null)
retval.push(arr[0]);
return retval;
},
setQuery : function(val1, val2) {
var a = this.QueryStrings();
var retval = "";
var seted = false;
var re = new RegExp("^" +val1+ "\=([^\&\?]*)$", "ig");
for(var i=0; i<a.length; i++) {
if (re.test(a[i])) {
seted = true;
a[i] = val1 +"="+ val2;
}
}
retval = a.join("&");
return "?" +retval+ (seted ? "" : (retval ? "&" : "") +val1+ "=" +val2);
}
}
alert(request.setQuery("e","b"))
//-->
</SCRIPT>.net