zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    linux学习之路7 linux下获取帮助
    51nod 1002 数塔取数问题
    51nod 1002 数塔取数问题
    51nod 1001 数组中和等于K的数对
    51nod 1001 数组中和等于K的数对
    linux学习之路6 Vi文本编辑器
    linux学习之路6 Vi文本编辑器
    计算误差——ACM计算几何中的精度问题
    计算误差——ACM计算几何中的精度问题
    daily_journal_3 the game of thrones
  • 原文地址:https://www.cnblogs.com/liuxiaoming123/p/7494125.html
Copyright © 2011-2022 走看看