刷新modalDialog的父窗口

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
  <html>
      <head>
          <title></title>
          <meta name="GENERATOR" content="Microsoft Visual Studio .NET 7.1">
          <meta name="ProgId" content="VisualStudio.HTML">
          <meta name="Originator" content="Microsoft Visual Studio .NET 7.1">
          <script language="javascript">
              <!--
             /**
             * 用途:打开模态窗口,并且当返回值为true时,刷新窗口
            *
           * @param newUrl        模态窗口页面路径
            * @param wLen        模态窗口宽度
           * @param iLen        模态窗口高度
           **/
             function OpenModalDialog(newURL,wLen,hLen)
             {
                 try
                {
                    //初始化变量,用于接收页面反回值。
                     var recdata=false;
                     //模式窗口打开指定的窗口链接
                     recdata=showModalDialog(newURL,"DescWindow",
                         "dialogWidth:"+wLen+"px;dialogHeight:"+hLen+"px;center:1;scroll:1;help:0;status:0");
 
                     //判断对应的返回值
                     if(recdata==true)
                     {
                         // 刷新当前窗口
                         window.location.reload();
                         window.alert("刷新窗口~~");
                     }
                 }
                 catch(err)
                {}
             }
             -->
     </script>
     </head>
     <body>
         <a href="javascript: OpenModalDialog('sub.aspx', 700, 500)">打开模态窗口</a>
     </body>
 </html>
 
2、建立页面sub.aspx:
  <%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="TestSyntax.WebForm1" %>
 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
 <HTML>
      <HEAD>
          <title>sub</title>
         <meta content="Microsoft Visual Studio .NET 7.1" name="GENERATOR">
          <meta content="C#" name="CODE_LANGUAGE">
          <meta content="JavaScript" name="vs_defaultClientScript">
          <meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema">
         <base target="_self">
     </HEAD>
     <body>
         <form id="Form1" method="post" runat="server">
             <asp:Button id="btnOk" runat="server" Text="确 定"></asp:Button>&nbsp;
             <INPUT type="button" value="取 消" οnclick="javascript: window.close();">
         </form>
     </body>
 </HTML>
 
3、sub.aspx.cs代码如下
  using System;
  using System.Collections;
  using System.ComponentModel;
  using System.Data;
  using System.Drawing;
  using System.Web;
  using System.Web.SessionState;
  using System.Web.UI;
  using System.Web.UI.WebControls;
 using System.Web.UI.HtmlControls;
 
 namespace TestSyntax
 {
     /// <summary>
     /// WebForm1 的摘要说明。
     /// </summary>
     public class WebForm1 : System.Web.UI.Page
     {
         protected System.Web.UI.WebControls.Button btnOk;
    
         private void Page_Load(object sender, System.EventArgs e)
         {
             // 在此处放置用户代码以初始化页面
         }
 
         #region Web 窗体设计器生成的代码
         override protected void OnInit(EventArgs e)
         {
             //
             // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
             //
             InitializeComponent();
             base.OnInit(e);
         }
        
         /// <summary>
         /// 设计器支持所需的方法 - 不要使用代码编辑器修改
         /// 此方法的内容。
         /// </summary>
         private void InitializeComponent()
         {   
             this.btnOk.Click += new System.EventHandler(this.btnOk_Click);
             this.Load += new System.EventHandler(this.Page_Load);
 
         }
         #endregion
 
         /// <summary>
         /// 操作成功,设定模态窗口的返回值为true,用来刷新父窗口
         /// </summary>
         /// <param name="sender"></param>
         /// <param name="e"></param>
         private void btnOk_Click(object sender, System.EventArgs e)
         {
             string strScript = @"<script>window.returnValue=true;window.close();</script>";
 
             this.Response.Write(strScript);
         }
     }
 }
 
这样,实现了操作成功后刷新父窗口,又避免了取消操作的无用刷新。


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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值