父窗口刷新子窗口 和子窗口刷新父窗口的js

本文介绍了解决IFrame内部链接状态不同步的问题,并提供了一个简单的JavaScript解决方案。此外,还分享了如何让子窗口在关闭时刷新父窗口的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天遇到一个问题是,主菜单放在一个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();即可刷新父窗口并且关闭子窗口.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值