父窗口和iframe子窗口之间相互传递参数和调用函数或方法
2015-11-18 12:17
525 查看
原文地址:http://www.cnblogs.com/hmyprograming/archive/2012/08/15/2640094.html
1.父窗口向子窗口传递参数:
可以在url中添加参数:2.html?a=1&b=2&c=3
然后在子页面上可用js解析,提供一个函数:
function getQueryStr(sArgName)
{
var args = LocString.split("?");
var retval = "";
if(args[0] == LocString) /*参数为空*/
{
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;
}
使用
var a=getQueryStr("a");
var b=getQueryStr("b");
var c=getQueryStr("c");
可以取得值
2.子页面向父页面传递参数:
可以换一个思路也就是在父页面中定义一个变量,然后在子页面中进行访问更改。
访问方法:window.parent.父窗口中的变量=xxx;
3.父页面调用子窗口方法
<iframe name="myFrame" src="child.html"></iframe>
myFrame.window.functionName();
4.子窗口调用父窗口方法
parent.functionName();
下面父窗口和子窗口相互调用举例:
父窗口页面
<html>
<head>
<script type="text/javascript">
function say() {
alert("parent.html------>I'm at parent.html");
}
function callChild()
{
//document.frames("myFrame").f1();
myFrame.window.say();
}
</script>
</head>
<body>
<input type=button value="调用child.html中的函数say()" onclick="callChild()">
<iframe name="myFrame" src="child.html"></iframe>
</body>
</html>
子窗口页面
<html>
<head>
<script type="text/javascript">
function say()
{
alert("child.html--->I'm at child.html");
}
function callParent() {
parent.say();
}
</script>
</head>
<body>
<input type=button value="调用parent.html中的say()函数" onclick="callParent()">
</body>
</html>
1.父窗口向子窗口传递参数:
可以在url中添加参数:2.html?a=1&b=2&c=3
然后在子页面上可用js解析,提供一个函数:
function getQueryStr(sArgName)
{
var args = LocString.split("?");
var retval = "";
if(args[0] == LocString) /*参数为空*/
{
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;
}
使用
var a=getQueryStr("a");
var b=getQueryStr("b");
var c=getQueryStr("c");
可以取得值
2.子页面向父页面传递参数:
可以换一个思路也就是在父页面中定义一个变量,然后在子页面中进行访问更改。
访问方法:window.parent.父窗口中的变量=xxx;
3.父页面调用子窗口方法
<iframe name="myFrame" src="child.html"></iframe>
myFrame.window.functionName();
4.子窗口调用父窗口方法
parent.functionName();
下面父窗口和子窗口相互调用举例:
父窗口页面
<html>
<head>
<script type="text/javascript">
function say() {
alert("parent.html------>I'm at parent.html");
}
function callChild()
{
//document.frames("myFrame").f1();
myFrame.window.say();
}
</script>
</head>
<body>
<input type=button value="调用child.html中的函数say()" onclick="callChild()">
<iframe name="myFrame" src="child.html"></iframe>
</body>
</html>
子窗口页面
<html>
<head>
<script type="text/javascript">
function say()
{
alert("child.html--->I'm at child.html");
}
function callParent() {
parent.say();
}
</script>
</head>
<body>
<input type=button value="调用parent.html中的say()函数" onclick="callParent()">
</body>
</html>
相关文章推荐
- STM32F103 与 STM32F207/407编程的区别自我总结
- ViewPage+Fragment的使用用法
- MySQL下常见的启动失败与备份失败问题的解决教程
- MySQL:存储过程和函数
- 数据驱动编程 游戏GM的实现
- Linux chmod命令修改文件与文件夹权限命令代码
- Oracle建立表空间、用户、授权
- MySQL:索引
- chmod命令详细用法
- Unicode utf8等编码类型的原理
- chmod 777 修改权限
- FSL安装
- MySQL:插入、更新与删除数据
- 08day03
- Android编程向服务器发送请求时出现中文乱码问题的解决方法
- Nodejs初阶之express
- To pack your python scripts to EXE by using PyInstaller3.0
- android中onInterceptTouchEvent()方法详解
- MySQL:查询数据
- C#取得当前目录 转载