html網頁如何傳遞接收地址參數?


  1 實現html頁面的參數傳遞
  2   
  3 方法一:
  4 下面是javascrīpt的一種實現方法, 這個函數是通過window.location.href中的分割符獲得各個參數。
  5 有了這個函數,就可以在頁面之間傳遞參數了。
  6 /*
  7 *函數功能:從href獲得參數
  8 *sHref:   http://www.artfh.com/arg.htm?arg1=d&arg2=re
  9 *sArgName:arg1, arg2
 10 *return:    the value of arg. d, re
 11 */
 12 function GetArgsFromHref(sHref, sArgName)
 13 {
 14       var args    = sHref.split("?");
 15       var retval = "";
 16      
 17       if(args[0] == sHref) /*參數為空*/
 18       {
 19            return retval; /*無需做任何處理*/
 20       }  
 21       var str = args[1];
 22       args = str.split("&");
 23       for(var i = 0; i < args.length; i ++)
 24       {
 25           str = args[i];
 26           var arg = str.split("=");
 27           if(arg.length <= 1) continue;
 28           if(arg[0] == sArgName) retval = arg[1]; 
 29       }
 30       return retval;
 31 }
 32 方法二:
 33 html地址傳遞參數進行其他事情.
 34 <scrīpt>
 35 /* 用途: 接收地直欄參數 取id=1 根據ID的值 */
 36 urlinfo=window.location.href; //獲取當前頁面的url
 37 len=urlinfo.length;//獲取url的長度
 38 offset=urlinfo.indexOf("?");//設置參數字符串開始的位置
 39 newsidinfo=urlinfo.substr(offset,len)//取出參數字符串 這里會獲得類似“id=1”這樣的字符串
 40 newsids=newsidinfo.split("=");//對獲得的參數字符串按照“=”進行分割
 41 newsid=newsids[1];//得到參數值
 42 newsname=newsids[0];//得到參數名字
 43 </scrīpt>
 44 方法三:
 45 <SCRIPT LANGUAGE="JavaScript">
 46 function getvalue(name){
 47     var str=window.location.search;   //location.search是從當前URL的?號開始的字符串 例如:http://www.51job.com/viewthread.jsp?tid=22720 它的search就是?
 48 tid=22720
 49     if (str.indexOf(name)!=-1){           
 50         var pos_start=str.indexOf(name)+name.length+1;
 51         var pos_end=str.indexOf("&",pos_start);
 52         if (pos_end==-1){
 53             alert( str.substring(pos_start));
 54         }else{
 55             alert("對不起這個值不存在!");
 56         }
 57     }
 58 </SCRIPT>
 59 方法四:
 60 做中英轉換的時候,要准確的獲取參數並取出,所以做了一個簡單的html中用js獲取當取地址欄的一個Object。 
 61 里面有三個方法: 
 62 1、request.QueryString("參數")//獲取指定參數,返回字符串; 
 63 2、request.QueryStrings();//獲取全部參數,並返回數組; 
 64 3、request.setQuery("參數","參數的值");//如果當前地址欄有此參數,那么將更新此參數,否則返回一個新的地址欄參數字符串。 
 65 例如: 
 66 當前地址欄參數字符串為:?name=a&site=never_online 
 67 alert(request.setQuery("name","blueDestiny")) 
 68 如果地址欄參數中有"name",那么返回?name=blueDestiny&site=never_online 
 69 setQuery方法有自動追加參數的功能。如: 
 70 當前地址欄參數字符串為:?site=never_online 
 71 alert(request.setQuery("name","blueDestiny")) 
 72 則返回?site=never_online&name=blueDestiny 
 73 同理,如果地址欄沒有參數,也會自動追加參數 
 74 alert(request.setQuery("name","blueDestiny")) 
 75 返回?name=blueDestiny 
 76 <SCRIPT LANGUAGE="JavaScript"> 
 77 <!-- 
 78 // author: never-online 
 79 // web: never-online.net 
 80 var request = { 
 81 QueryString : function(val) { 
 82 var uri = window.location.search; 
 83 var re = new RegExp("" +val+ "\=([^\&\?]*)", "ig"); 
 84 return ((uri.match(re))?(uri.match(re)[0].substr(val.length+1)):null); 
 85 }, 
 86 QueryStrings : function() { 
 87 var uri = window.location.search; 
 88 var re = /\w*\=([^\&\?]*)/ig; 
 89 var retval=[]; 
 90 while ((arr = re.exec(uri)) != null) 
 91 retval.push(arr[0]); 
 92 return retval; 
 93 }, 
 94 setQuery : function(val1, val2) { 
 95 var a = this.QueryStrings(); 
 96 var retval = ""; 
 97 var seted = false; 
 98 var re = new RegExp("^" +val1+ "\=([^\&\?]*)$", "ig"); 
 99 for(var i=0; i<a.length; i++) { 
100 if (re.test(a[i])) { 
101 seted = true; 
102 a[i] = val1 +"="+ val2; 
103 } 
104 } 
105 retval = a.join("&"); 
106 return "?" +retval+ (seted ? "" : (retval ? "&" : "") +val1+ "=" +val2); 
107 } 
108 } 
109 alert(request.setQuery("e","b")) 
110 //--> 
111 </SCRIPT>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM