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>