Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 编程语言 > .NET > C#.NET > Web开发:"父窗口"与"弹出子窗口"之间的刷新, 传值
【标  题】:Web开发:"父窗口"与"弹出子窗口"之间的刷新, 传值
【关键字】:Web
【来  源】:http://maxwolf.cnblogs.com/archive/2005/12/06/291889.html

Web开发:"父窗口"与"弹出子窗口"之间的刷新, 传值

Your Ad Here

               
      Web开发中适当运用一些弹
出子窗口有很多好处,可以节省页面设计代价,获得好的用户体验,在最近项目开发中我遇到了几个父子窗口的问题,现在整理给大家,希望有所帮助.
              
   情景一: 打开某一子窗口, 子窗口中任一按钮点击时候不能弹出新页面,进行完操作后,关闭该子窗口,刷新父窗口.        
       
                 1: 页面A:父窗口,其中有一个打开子窗口的链接,<a  href="#"onclick="open()">页面C</a>
                      A中有如下js代码:

<script language="JavaScript">
   
function open()
   {
     window
.showModalDialog("页面B");
   }
</script>

                2: 页面B,此为中间页,起过渡作用
                     B html 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>**</title>
</head>

<frameset rows="0,*">
    
<frame src="about:blank">
    
<frame src="页面C">
  
</frameset><noframes></noframes>
</html>

                 3:页面C ,要打开的子窗口.
                    它关闭时候刷新父窗口很简单,只要把A中
                    <a  href="#"onclick="open()">页面C</a>  改为
                    <a  href="页面A"onclick="open()">页面C</a>

    情景二:打开某一需要用到activex控件子窗口, 子窗口中任一按钮点击时候不能弹出新页面,进行完操作后,关闭该子窗口,刷新父窗口.  
                  此时候就不能用 window.showModalDialog()事件打开模式对话框了因为activex控件会报错,必须用window.open()
 
                  1: 页面A:父窗口,其中有一个打开子窗口的链接,<a  href="#"onclick="open()">页面B</a>
                      A中有如下js代码.

<script language="JavaScript">
function open()
 {
   window
.open("页面B",'upload', 'height=400, width=420, top=0, left=0, toolbar=no, menubar=no,scrollbars=no, resizable=no,location=no, status=no');
 }
</script>

                  2: 页面B,要打开的子窗口,关闭时候触发window.opener.location.reload();window.close();即可刷新父窗口并且关闭子窗口.

   
     情景三:打开某一子窗口,   让用户选择要添加的东东,譬如要添加到文章里的相片选择后关闭子窗口,然后选择的东东出现在父窗口里.
                    在下图中,我点击"添加照片"链接然后弹出子窗口,在子窗口中选择后点击"添加照片"按钮,子窗口自动关闭,并且父窗口"已添加照片:"下面列出了我选择的照片。

        
      
            

               实现方法:类似情景一需要中间页面B , 只是子窗口C中点击"添加按钮"时触发的js事件中,除了获得选中的checkbox的值外,还要把获得的值回传给父窗口,传值回去的代码如下.
              

window.parent.returnValue="选中的checkbox";
               window
.parent.close();

 
              而父窗口要捕获此值就要在情景一中所说的open()事件中添加获得返回值 

<script language="JavaScript">
  
function open()
   {
         
var str=window.showModalDialog("页面C");
         
if(str!=null)  
       {              
          picobj
.innerHTML+=str; 
          
       }
    }
</script>

               注意这里的str是获取的返回值, 而picobj是你要显示被选择东东所放位置的div的id ,这里是<div id=picobj></div>

[ASP.NET入门随想四]吸星大法——页面的OO思想篇:【上一篇】
使用简单的Ajax Framework -MagicAjax.NET:【下一篇】
【相关文章】
  • 动态调用web服务
  • Web 2.0的关键特征
  • web 服务实现步骤
  • 技术评论与随想——AJAX、Rails、WebFramework、SSE
  • WebWork和Struts的合并,如果是这样-->
  • Asp.net 2.0 WebPart使用经验点滴
  • Asp.net 2.0功能体验,细节之Web控件(一) 隐藏控件
  • 深入学习Web Service系列之异步开发模式
  • 只需3步把您的Java程序转换为Web服务
  • AJAX及使用E4X编写Web服务脚本系列之一
  • 【随机文章】
  • Java Web Application开发日志之五--“design with the think of sharing objects”,Flyweight模式应用
  • 总体了解C#(25.库-26.互用性)
  • 基于.NET数字处理程序的框架设计
  • 3ds Max 7 界面及常用功能改进(2)
  • 一条命令行解决问题! Susel linux系统
  • 一些公司网络管理监控软件的测评
  • 一种效率极高的分类算法 
  • cownew开源-eclipse插件开发学习知识点笔记
  • omega 系统的安装
  • 在ASP中利用COM组件开发Web应用程序
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.