JS當(dāng)前頁(yè)面和框架自動(dòng)刷新的方法

發(fā)布時(shí)間:   瀏覽: 3305

先來看一個(gè)簡(jiǎn)單的例子:

下面以三個(gè)頁(yè)面分別命名為frame.html、top.html、bottom.html為例來具體說明如何做。

frame.html 由上(top.html)下(bottom.html)兩個(gè)頁(yè)面組成,代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

<TITLE> frame </TITLE>

</HEAD>

<frameset rows="50%,50%">

<frame name=top  src="top.html">

<frame name=bottom  src="bottom.html">

</frameset>

</HTML>

現(xiàn)在假設(shè)top.html (即上面的頁(yè)面) 有七個(gè)button來實(shí)現(xiàn)對(duì)bottom.html (即下面的頁(yè)面) 的刷新,可以用以下七種語(yǔ)句,哪個(gè)好用自己看著辦了。

語(yǔ)句1. window.parent.frames[1].location.reload();

語(yǔ)句2. window.parent.frames.bottom.location.reload();

語(yǔ)句3. window.parent.frames["bottom"].location.reload();

語(yǔ)句4. window.parent.frames.item(1).location.reload();

語(yǔ)句5. window.parent.frames.item('bottom').location.reload();

語(yǔ)句6. window.parent.bottom.location.reload();

語(yǔ)句7. window.parent['bottom'].location.reload();

top.html 頁(yè)面的代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

  <TITLE> top.html </TITLE>

</HEAD>

<BODY>

<input type=button value="刷新1" onclick="window.parent.frames[1].location.reload()"><br>

<input type=button value="刷新2" onclick="window.parent.frames.bottom.location.reload()"><br>

<input type=button value="刷新3" onclick="window.parent.frames['bottom'].location.reload()"><br>

<input type=button value="刷新4" onclick="window.parent.frames.item(1).location.reload()"><br>

<input type=button value="刷新5" onclick="window.parent.frames.item('bottom').location.reload()"><br>

<input type=button value="刷新6" onclick="window.parent.bottom.location.reload()"><br>

<input type=button value="刷新7" onclick="window.parent['bottom'].location.reload()"><br>

</BODY>

</HTML>

下面是bottom.html頁(yè)面源代碼,為了證明下方頁(yè)面的確被刷新了,在裝載完頁(yè)面彈出一個(gè)對(duì)話框。

bottom.html 頁(yè)面的代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

  <TITLE> bottom.html </TITLE>

</HEAD>

<BODY onload="alert('我被加載了!')">

<h1>This is the content in bottom.html.</h1>

</BODY>

</HTML>

解釋一下:

1.window指代的是當(dāng)前頁(yè)面,例如對(duì)于此例它指的是top.html頁(yè)面。

2.parent指的是當(dāng)前頁(yè)面的父頁(yè)面,也就是包含它的框架頁(yè)面。例如對(duì)于此例它指的是framedemo.html。

3.frames是window對(duì)象,是一個(gè)數(shù)組。代表著該框架內(nèi)所有子頁(yè)面。

4.item是方法。返回?cái)?shù)組里面的元素。

5.如果子頁(yè)面也是個(gè)框架頁(yè)面,里面還是其它的子頁(yè)面,那么上面的有些方法可能不行。

附:

Javascript刷新頁(yè)面的幾種方法:

1    history.go(0)

2    location.reload()

3    location=location

4    location.assign(location)

5    document.execCommand('Refresh')

6    window.navigate(location)

7    location.replace(location)

8    document.URL=location.href

 

自動(dòng)刷新頁(yè)面的方法:

1.頁(yè)面自動(dòng)刷新:把如下代碼加入<head>區(qū)域中

<meta http-equiv="refresh" content="20">

其中20指每隔20秒刷新一次頁(yè)面.

2.頁(yè)面自動(dòng)跳轉(zhuǎn):把如下代碼加入<head>區(qū)域中

<meta http-equiv="refresh" content="20;url=http://www.wyxg.com">

其中20指隔20秒后跳轉(zhuǎn)到http://www.wyxg.com頁(yè)面

3.頁(yè)面自動(dòng)刷新js版

<script language="JavaScript">

function myrefresh()

{

       window.location.reload();

}

setTimeout('myrefresh()',1000); //指定1秒刷新一次

</script>

ASP.NET如何輸出刷新父窗口腳本語(yǔ)句

1.   this.response.write("<script>opener.location.reload();</script>");  

2.   this.response.write("<script>opener.window.location.href = opener.window.location.href;</script>");   

3.   Response.Write("<script language=javascript>opener.window.navigate(''你要刷新的頁(yè).asp'');</script>")

JS刷新框架的腳本語(yǔ)句

//如何刷新包含該框架的頁(yè)面用   

<script language=JavaScript>

   parent.location.reload();

</script>   

//子窗口刷新父窗口

<script language=JavaScript>

    self.opener.location.reload();

</script>

( 或 <a href="javascript:opener.location.reload()">刷新</a>   )

//如何刷新另一個(gè)框架的頁(yè)面用   

<script language=JavaScript>

   parent.另一FrameID.location.reload();

</script>

如果想關(guān)閉窗口時(shí)刷新或者想開窗時(shí)刷新的話,在<body>中調(diào)用以下語(yǔ)句即可。

<body onload="opener.location.reload()"> 開窗時(shí)刷新

<body onUnload="opener.location.reload()"> 關(guān)閉時(shí)刷新

<script language="javascript">

window.opener.document.location.reload()

</script>