`
yanglei008
  • 浏览: 84880 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

父子窗口间传值

    博客分类:
  • js
阅读更多
父窗口:

url = url + '?winFlg=aaa&winPig=bbb';

window.open(url, '', '');

子窗口:

var URLParams = new Object();
var aParams = document.location.search.substr(1).split('&');
for (var i=0; i < aParams.length; i++) {
    var aParam = aParams[i].split('=');
     URLParams[aParam[0]] = aParam[1];
}

alert(URLParams["winFlg"]);

alert(URLParams["winPig"]);

==================================================================================

打开一个新窗口,该子窗口调用父对象的方法或变量,这个问题一直没有搞清楚。网上找了些资料,总结一下:

打开新窗口一般有几种方法,window.open(...),window.showModalDialog(...),以及iframe中嵌套页面这里也一起研究吧,另外还有window.navigate(...)、window.location.href="..."、window.history.back(-1);都是实现同意页面内容跳转的,这里不讨论。

1、open子窗口:用window.opener代表父窗口的window对象

2、模态子窗口:间接通过传window对象到子窗口,然后子窗口可获得父窗口的window对象

3、iframe中子页面:用window.parent代表父窗口的window对象


父页面:1.htm    代码:

<html>
<head>
<title>打开父子窗口传值研究-父窗口</title>

<script >
var parValue="现在显示了父窗口中的变量值";

function test(){
alert("现在显示了父窗口中的方法正常执行");
}

</script>
</head>
<body >
<input type="button" id="mybutton1"    value="打开open新窗口"    onclick="window.open('2.htm');">
<input type="button" id="mybutton2"    value="打开modal窗口"    onclick="window.showModalDialog('3.htm',window);" >
<br>
<iframe id="subiframe"    name="subiframe"     src="4.htm" scrolling="auto" frameborder="1" ></iframe>
</body>
</html>


2.htm 代码:

<html>
<head>
<title>打开父子窗口传值研究-open打开子窗口</title>
<script>
var buttonValue=window.opener.document.getElementById("mybutton2").value //获取父窗口中的对象
var parentValue=window.opener.parValue;       //获取父窗口中的变量

function doParTest(){
window.opener.test();        //调用父窗口中的方法

}
</script>
</head>
<body>

<input type="button" value="open打开子窗口按钮" onclick="alert('buttonValue:'+buttonValue);alert('parentValue:'+parentValue);doParTest()">

</body>
</html>


3.htm 代码:

<html>
<head>
<title>打开父子窗口传值研究-打开modal子窗口</title>
<script>
var parentWin=window.dialogArguments;
var buttonValue=parentWin.document.getElementById("mybutton2").value   //获取父窗口中的对象
var parentValue=parentWin.parValue;       //获取父窗口中的变量
function doParTest(){
parentWin.test();        //调用父窗口中的方法
}
</script>
</head>

<body bgcolor="#FFFFFF" text="#000000">

<input type="button" value="modal子窗口按钮" onclick="alert('buttonValue:'+buttonValue);alert

('parentValue:'+parentValue);parentWin.test();">
</body>
</html>


4.htm    代码:

<html>
<head>
<title>打开父子窗口传值研究-iframe中子窗口</title>
<script>
var buttonValue=window.parent.document.getElementById("mybutton2").value //获取父窗口中的对象
var parentValue=window.parent.parValue;       //获取父窗口中的变量

function doParTest(){
window.parent.test();        //调用父窗口中的方法
}
</script>
</head>
<body>

<input type="button" value="iframe中子窗口按钮" onclick="alert('buttonValue:'+buttonValue);alert('parentValue:'+parentValue);doParTest()">

</body>
</html>
 


下面是自己写了一个测试例子:
test1:
<input type="text" id="txt">
<div style="float:left;" id="div" ></div>
<input type="button" value="open" onClick="openWindow()">

<script>
function openWindow(){

  var result=window.showModalDialog("test2.html",window);
	alert(result);
  var arr = result.split('_');
  var arrCodes = arr[0].split(',');
  var arrNames = arr[1].split(',');
  document.getElementById('txt').value=arr[1];
  
  var innerH = '';
  for(var i=0;i<arrCodes.length-1;i++){
  	innerH+='<input type=\"text\" name=\"old\" value=\"'+arrCodes[i]+'\" />'
  }
  document.getElementById('div').innerHTML=innerH;
  
}
</script>


test2:



<html>
	<head>
<script>

function onload(){
	
	var parentWin = window.dialogArguments;
	var obj = parentWin.document.getElementsByName('old');
	var oldValues = new Array();
	for(var i=0;i<obj.length;i++){
		oldValues[i]=obj[i].value;
	}
	
	var obj = document.getElementsByName('selectValues');
	for(var i = 0;i<obj.length;i++){
		for(var j=0;j<oldValues.length;j++){
			if(obj[i].value == oldValues[j])
			{ obj[i].checked='checked';}
		}
	
}
}
	

function ok(){
		
 var industryCodes = new Array();
 var industryNames = new Array();	
	
	  var tmpCodes = '';
    var tmpNames = '';
    var codes = document.getElementsByName("selectValues");
    var names = document.getElementsByName("selectNames");

    for(var i =0 ,j=0 ; i <codes.length;i++){
        if(codes[i].checked){
            tmpCodes  += codes[i].value+',';
            tmpNames += names[i].value+',';
            j++;
        }
    }

   var tmpValue =tmpCodes+'_'+tmpNames;
   
   window.returnValue = tmpValue;
   window.close();
}	
</script>	
</head>

<body onload="onload()">
<input type="text" id="test1" value="" />
<input type="checkbox" name="selectValues" value="1" />文本1<input type="hidden" name="selectNames" value="文本1" />
<br>
<input type="checkbox" name="selectValues" value="2" />文本2<input type="hidden" name="selectNames" value="文本2" />
<br>
<input type="checkbox" name="selectValues" value="3" />文本3<input type="hidden" name="selectNames" value="文本3" />
<br>
<input type="button" onclick="ok()" />
</body>
</html>



模态弹出窗口

 returnValue除了可以是布尔值,整型值等以外还可以是个js数组,用来传递大量数据。

 showModalDialog,是模态窗口,始终获得焦点,但弹出的窗体不能刷新,此弹出的窗口 里操作button,要想不弹出新窗口,需在

弹出的窗口中在<head>和</head>之间加<base target="_self">。


分享到:
评论
2 楼 JEBAIKEjava2012 2012-05-18  
太好了,帮了大忙了。。。
1 楼 topbox163 2010-04-27  
谢了。。。。。。。。。。。。

相关推荐

    父子窗口间传值、CListCtrl隔行变色

    最后,父子窗口间的数据传递是一个重要的设计概念。在MFC中,通常使用消息、成员变量或者事件通知来实现。例如,子窗口可以通过发送自定义消息(使用SendMessage或PostMessage函数)给父窗口,携带需要传递的数据。...

    QT父子窗口相互传值

    "QT父子窗口相互传值"这个主题,主要涉及Qt框架中如何有效地实现这种通信机制。本篇文章将详细探讨Qt窗口之间传递数据的方法和技巧,对初学者来说尤其具有指导意义。 首先,让我们理解Qt中的窗口对象关系。在Qt中,...

    pyqt父子窗口相互传值

    "pyqt父子窗口相互传值"这个主题就是关于如何在不同的QMainWindow或QWidget实例之间传递数据。下面将详细讲解这个过程,并提供一个可能的实现方式。 首先,我们需要理解PyQt中的窗口层次结构。在PyQt5中,窗口通常...

    C#实现父子窗体全传值案例

    总之,"C#实现父子窗体全传值案例"涵盖了窗口交互、模态对话框使用以及数据传递等多个关键点,这些都是在开发C#桌面应用程序时不可或缺的知识。通过深入理解并实践这些概念,开发者能够构建更加灵活和健壮的应用程序...

    window.open父子窗口传值问题

    当我们谈论“window.open父子窗口传值问题”,我们指的是在父窗口通过`window.open`创建了一个子窗口,并需要在两者之间进行数据通信的情况。 首先,让我们了解一下`window.open`的基本语法: ```javascript var ...

    动态增删table以及后台传值和弹出窗口父子窗口传值

    弹出窗口父子窗口传值主要指的是在Web应用中打开新窗口或弹出对话框时,两个窗口之间数据的交换。在JavaScript中,可以使用window.open()函数创建新窗口,并通过window对象的属性(如opener或parent)来访问父窗口或...

    两个窗口传值

    在IT领域,尤其是在软件开发中,"两个窗口传值"通常指的是在两个应用程序窗口或同一应用程序中的两个界面之间交换数据的过程。这个问题涉及到进程通信、跨线程通信等复杂概念,这些是多任务操作系统中实现不同组件间...

    javascript 父窗口、子窗口传值问题

    在JavaScript编程中,父窗口与子窗口之间的通信是一种常见的需求,特别是在构建多...在实际应用中,根据场景和安全性要求选择合适的方法进行父子窗口间的通信。同时,要确保遵循同源策略,因为跨域通信可能会受到限制。

    js操作模态窗口及父子窗口间相互传值示例

    父子窗口间的相互传值是Web开发中经常遇到的一个需求,尤其当模态窗口被用作子窗口时。本文将详细介绍如何使用JavaScript来操作模态窗口,并实现父子窗口之间的数据传递。 首先,我们要了解什么是模态窗口以及如何...

    python Qt5GUI界面主窗口和子窗口相互传值,保证能用

    在Qt设计中,窗口间通信通常是通过信号(Signals)和槽(Slots)机制进行的,这是一种事件驱动的编程模式。 1. **信号和槽的概念** - **信号(Signals)**:当某个事件发生时,Qt对象会发出一个信号。例如,当用户...

    asp.net 父子页面传值

    本文将深入探讨如何在ASP.NET环境中实现父子页面间的值传递,并分享一些实用的技术和策略。 首先,我们要了解ASP.NET页面生命周期的基础知识。每个ASP.NET页面都有自己的生命周期,包括初始化、加载事件、验证、...

    JS简单实现父子窗口传值功能示例【未使用iframe框架】

    本文实例讲述了JS简单实现父子窗口传值功能。分享给大家供大家参考,具体如下: 父窗口页面father.html &lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"&gt; &lt;HTML&gt; &lt;HEAD&gt; &lt;TITLE&...

    Qt--子窗口向父窗口传值

    2. **父子窗口关系**: - 在Qt中,`QMainWindow`通常作为主窗口,而其他如`QWidget`或自定义窗口类可以作为子窗口或对话框。 - 子窗口通常是模态或非模态的,它们可以在主窗口之上弹出,并在完成任务后关闭。 3. ...

    [C# 窗体间传值_共6种方法_低中高级实现方法

    在C#编程中,窗口间的数据传递是一项基本且重要的任务,尤其在开发多窗口应用程序时。SongQz编写的这篇文章汇总了六种不同级别的方法,从初级到高级,旨在帮助开发者掌握各种技巧,确保在不同窗口之间有效地交换数据...

    ie+FF通用的父子模态对话框相互传值

    总的来说,实现"ie+FF通用的父子模态对话框相互传值"涉及到JavaScript的事件处理、跨窗口通信和CSS的模态设计。理解这些知识点并熟练运用,能帮助开发者创建出更好的交互体验。同时,要时刻关注浏览器的兼容性和最佳...

    iframe父子传值

    然而,当涉及到`iframe`中的父子窗口间通信时,开发者可能会遇到一些挑战。本文将详细介绍如何在`iframe`的父窗体与子窗体之间进行数据传递。 ### 1. 同源策略与跨域限制 首先,我们需要了解浏览器的安全机制——...

    父子窗口传值window.showModalDialog以及window.open用法简介

    window.showModalDialog以及window.open用法简介

Global site tag (gtag.js) - Google Analytics