zoukankan      html  css  js  c++  java
  • 父窗口刷新子窗口 和子窗口刷新父窗口的js

    今天遇到一个问题是,主菜单放在一个iframe里面的,而且链接是采用js控制的,即当前页面对应的链接都用红色显示。但是当点击父窗口的链接更换main里面的内容的时候iframe里面的链接却没有改变。刚开始还想通过内容显示区的内容来判断,但马上意识都这样不行,后来又想通过父窗口的链接和子窗口的链接关联起来,这样仍然很麻烦。最后想到了当点击父窗口的链接时,内容显示区的内容也就变化了,那么子窗口的状态就应该是加载时候的状态了,只要刷新一下就可以了。

    马上到网上搜索,结果很失望,搜索到的都是子窗口刷新父窗口的js,却没有父窗口刷新子窗口的js代码。后来转念一想--父窗口刷新子窗口不就是改变src的链接就ok了吗?马上动手,效果马上就出来了,就两行代码,简单到你不敢相信!

    /*
    zdz的作品,流风的作品
    */

    function reloadleft(){
    var leftiframeid = document.getElementById('left');//left为对应iframe的id
    leftiframeid.src = "left.html";//ileft.html为frame的页面
    }

    链接里面加入onclick="reloadleft()"就可以了。

    <a href="contact.html" target="main" title="点击查看" onclick="reloadleft()">联系我们</a>

    跳转页面的js:window.location.href="new.html"

    ------------------------

    下面是搜集的子窗口刷新父窗口的js

    self.opener.location.reload();

    window.opener.location.reload(); //关键是这句:刷新父窗口

    ------------------------

    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>

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

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

            
          
                

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

        情景二:打开某一需要用到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>

    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>

  • 相关阅读:
    关于返回上一页功能
    Mybatis Update statement Date null
    SQLite reset password
    Bootstrap Validator使用特性,动态(Dynamic)添加的input的验证问题
    Eclipse使用Maven2的一次环境清理记录
    Server Tomcat v7.0 Server at localhost failed to start
    PowerShell一例
    Server Tomcat v7.0 Server at libra failed to start
    商标注册英语
    A glance for agile method
  • 原文地址:https://www.cnblogs.com/wubin264/p/1394267.html
Copyright © 2011-2022 走看看