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>

  • 相关阅读:
    莫名其妙的float:left; 不能使元素紧贴父级的坑
    将HTML元素转换成图片供用户下载(html2canvas + canvas2Image)
    使用Git代替FTP进行虚拟主机的代码管理
    jQuery: on()特别的几种用法
    监控页面后退前进,浏览器文档加载事件之pageshow、pagehide
    博客园Markdown编辑器试玩~~~
    移动端调试神器(eruda)
    移动端分享插件使用总结
    sqlloader的使用------windows版
    运维工作总结教训
  • 原文地址:https://www.cnblogs.com/wubin264/p/1394267.html
Copyright © 2011-2022 走看看