js怎样获取iframe,src中的参数

js怎样获取iframe,src中的参数,第1张

/

    取得目标iframe src所包含的参数

    @param iframeId - 目标iframe的id

    @return Object 参数名值对,{参数名:参数值,……}

/

function getIframeParams(iframeId) {

    var regexpParam = /\([\w\d%]+)=([\w\d%])&/g; //分离参数的正则表达式

    var targetEle = documentgetElementById(iframeId);

    

    var paramMap = null;

    

    if(!!targetEle) {

        var url = targetElesrc; //取得iframe的url

        

        var ret;

        

        paramMap = {};//初始化结果集

        

        //开始循环查找url中的参数,并以键值对形式放入结果集

        while((ret = regexpParamexec(url)) != null) {

                //ret[1]是参数名,ret[2]是参数值

            paramMap[ret[1]] = ret[2];

        }

    }

    

    return paramMap; //返回结果集

}

用法:

假设iframe如下

<html>

    <head>

    </head>

    <body>

        <iframe id="test" src="urlparamA=a&paramB=b"></iframe>

    </body>

</html>//获取参数名值对集合

var paramMap = getIframeParams('test');

//paramMap的结构是这样的:{'paramA':'a', 'paramB':'b'}

alert(paramMapparamA); //取出paramA的参数值

什么是request对象

Request对象的作用是与客户端交互,收集客户端的Form、Cookies、超链接,或者收集服务器端的环境变量。

request对象是从客户端向服务器发出请求,包括用户提交的信息以及客户端的一些信息。客户端可通过HTML表单或在网页地址后面提供参数的方法提交数据,然后通过request对象的相关方法来获取这些数据。request的各种方法主要用来处理客户端浏览器提交的请求中的各项参数和选项。

在JS中获取到request,网页地址的方法:

windowlocationhref

这里假设URL完整为:baiducom/indexhtmltest=233333

这里要取request中值的属性,可以使用正则表达式获取

正则表达式,又称规则表达式。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表通常被用来检索、替换那些符合某个模式(规则)的文本。

首先使用RegExp构造一个正则正则表达式对象

var reg = new RegExp("(^|/|&)test=([^&])(&|$)", "i");

参数

pattern             一个字符串,指定了正则表达式的模式或其他正则表达式。

attributes          可选的字符串,包含属性 "g"、"i" 和 "m",分别用于指定全局匹配、区分大小写的匹配和多行匹配。ECMAScript 标准化之前,不支持 m 属性。如果 pattern 是正则表达式,而不是字符串,则必须省略该参数。

修饰符

i    执行对大小写不敏感的匹配。  

g    执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。  

m    执行多行匹配。  

然后使用match匹配出结果来

var match= windowlocationhrefmatch(reg);

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

参数

searchvalue    规定要检索的字符串值。  

regexp            规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象,则需要首先把它传递给 RegExp 构造函数,将其转换为 RegExp 对象。  

取出结果

match[2]

返回:233333

将它封装为一个函数

function getRequestValue(name) { 

var reg = new RegExp("(^|/|&)" + name + "=([^&])(&|$)", "i"); 

var match= windowlocationhrefmatch(reg); 

return match&&match[2]||null;

}

完整实例代码:

<html>

<head>

<title></title>

</head>

<body>

</body>

<script type="text/javascript">

function getValue(name) { 

var reg = new RegExp("(^|/|&)" + name + "=([^&])(&|$)", "i"); 

var match= windowlocationhrefmatch(reg); 

return match&&match[2]||null;

}

consolelog(getValue('test'));

</script>

</html>

JS使用post提交的两种方式。分享给大家供大家参考,具体如下:

第一种提交post的方式是传统方式,判断浏览器进行post请求。

<SCRIPT stype=text/javascript>

var xmlobj; //定义XML>}

第二种方式则是虚拟表单的形式提交post请求

function post(URL, PARAMS) {

var temp = documentcreateElement("form");

tempaction = URL;

tempmethod = "post";

tempstyledisplay = "none";

for (var x in PARAMS) {

var opt = documentcreateElement("textarea");

optname = x;

optvalue = PARAMS[x];

// alert(optname)

tempappendChild(opt);

}

documentbodyappendChild(temp);

tempsubmit();

return temp;

}

调用方法 如:

复制代码 :

post('pages/statisticsJsp/excelaction',{html:prnhtml,cm1:'sdsddsd',cm2:'haha'});

你这个不是标准的>

hrequest = {};

hjrequestget = function (paramName) { var aParams = documentlocationsearchsubstr(1)split('&'); for (i = 0; i < aParamslength; i++) { var aParam = aParams[i]split('='); if (paramNametoLowerCase() == aParam[0]toLowerCase()) return aParam[1]trim(); }; return ""; };

hjrequestgetUrl = function () { return toplocationhref; };

hjrequestgetRef = function () { return documentreferrer; };参数名可以自己改,放在公共类里面当成自己的类使用

方法一:采用正则表达式获取地址栏参数:( 强烈推荐,既实用又方便!)加密参数在获取到值后解密就可以了

function GetQueryString(name)

{

    var reg = new RegExp("(^|&)"+ name +"=([^&])(&|$)");

    var r = windowlocationsearchsubstr(1)match(reg);

    if(r!=null)

        return unescape(r[2]); //解密

  else

    return null;

}

 

// 调用方法

alert(GetQueryString("参数名1"));

alert(GetQueryString("参数名2"));

alert(GetQueryString("参数名3"));

方法二:传统方法

function UrlSearch() {   

    var name,value;

    var str=locationhref; //取得整个地址栏   

    var num=strindexOf("");    

    str=strsubstr(num+1); //取得所有参数stringvarsubstr(start [, length ]

   var arr=strsplit("&"); //各个参数放到数组里   

   for(var i=0;i < arrlength;i++){     

     num=arr[i]indexOf("=");     

     if(num>0){      

       name=arr[i]substring(0,num);     

       value=arr[i]substr(num+1);     

       this[name]=value;     

       }     

      } 

//调用

var Request=new UrlSearch(); //实例化

alert(Requestid);

以上就是关于js怎样获取iframe,src中的参数全部的内容,包括:js怎样获取iframe,src中的参数、js函数中怎么获取request中值的属性、怎样获取js中post提交的数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/10174148.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存