html网页如何传递接收地址参数

html网页如何传递接收地址参数

1、通过window.location.href中的分割符获得各个参数

/*
  *函数功能:从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;
 }

2、html地址传递参数:

<script>
/* 用途: 接收地址栏参数*/
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];//得到参数名字
</script>

3、window.location.search:

<SCRIPT LANGUAGE="JavaScript">
function getvalue(name){
    var str=window.location.search;   //location.search是从当前URL的?号开始的字符串 例如:http://www.51job.com/viewthread.jsp?tid=22720 它的search就是?
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("对不起这个值不存在!");
        }
    }
</SCRIPT>

4、js获取当取地址栏的Object:

里面有三个方法:
1、request.QueryString(“参数”)//获取指定参数,返回字符串;

当前地址栏参数字符串为:?name=a&site=never_online
alert(request.setQuery("name","blueDestiny"))
如果地址栏参数中有"name",那么返回?name=blueDestiny&site=never_online

2、request.QueryStrings();//获取全部参数,并返回数组;
3、request.setQuery(“参数”,“参数的值”);//如果当前地址栏有此参数,那么将更新此参数,否则返回一个新的地址栏参数字符串。

setQuery方法有自动追加参数的功能。如:
当前地址栏参数字符串为:?site=never_online
alert(request.setQuery("name","blueDestiny"))
则返回?site=never_online&name=blueDestiny
同理,如果地址栏没有参数,也会自动追加参数
alert(request.setQuery("name","blueDestiny"))
返回?name=blueDestiny
<SCRIPT LANGUAGE="JavaScript">
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>

iframe嵌套网页消息传递,传递参数

A页面 中嵌套B页面 并向B页面传递消息:
A页面:

<iframe name="iframeA" src="http://xxx.B.html"></iframe>
 
<script>
    //发送消息
    window.onload = function(){
        var params = {name:'xxx'};
        var obj = JSON.stringify(params);
        window.frames['iframeA'].postMessage(obj,'http://xxx.B.html')
    }
</script>

B页面:

<script>
 
window.onload = function(){
    //判断是否被嵌套    
    if(window.parent != window){
        window.addEventListener('message',function(e){
            //这里会发现函数执行两次 一次返回string,一次返回object 小编也不知道是什么原因,因此加了判断
            if(typeof e.data === 'string'){ 
                var obj = JSON.parse(e.data) // 获取到A页面传来的值
            }
        })
    }
}
 
</script>
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值