zoukankan
html css js c++ java
javascript 刷新技巧
声明:
最近越来越感觉JS的优越性,项目中用到关于框架页面刷新的方法,在网上搜索以后发现有许多不错的代码,但不是很齐全。于是,我索性从网络上搜集以后经过精心编排,整理了一下。
^
-
^
希望大家多多指教!
先来看一个简单的例子:
下面以三个页面分别命名为frame.html、top.html、bottom.html为例来具体说明如何做。
frame.html 由上(top.html)下(bottom.html)两个页面组成,代码如下:
<!
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
>
现在假设top.html (即上面的页面) 有七个button来实现对bottom.html (即下面的页面) 的刷新,可以用以下七种语句,哪个好用自己看着办了。
语句1. window.parent.frames[
1
].location.reload();
语句2. window.parent.frames.bottom.location.reload();
语句3. window.parent.frames[
"
bottom
"
].location.reload();
语句4. window.parent.frames.item(
1
).location.reload();
语句5. window.parent.frames.item(
'
bottom
'
).location.reload();
语句6. window.parent.bottom.location.reload();
语句7. window.parent[
'
bottom
'
].location.reload();
top.html 页面的代码如下:
<!
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页面源代码,为了证明下方页面的确被刷新了,在装载完页面弹出一个对话框。
bottom.html 页面的代码如下:
<!
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指代的是当前页面,例如对于此例它指的是top.html页面。
2
.parent指的是当前页面的父页面,也就是包含它的框架页面。例如对于此例它指的是framedemo.html。
3
.frames是window对象,是一个数组。代表着该框架内所有子页面。
4
.item是方法。返回数组里面的元素。
5
.如果子页面也是个框架页面,里面还是其它的子页面,那么上面的有些方法可能不行。
附:
Javascript刷新页面的几种方法:
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
自动刷新页面的方法:
1
.页面自动刷新:把如下代码加入
<
head
>
区域中
<
meta http
-
equiv
=
"
refresh
"
content
=
"
20
"
>
其中20指每隔20秒刷新一次页面.
2
.页面自动跳转:把如下代码加入
<
head
>
区域中
<
meta http
-
equiv
=
"
refresh
"
content
=
"
20;url=http://www.wyxg.com
"
>
其中20指隔20秒后跳转到http:
//
www.wyxg.com页面
3
.页面自动刷新js版
<
script language
=
"
JavaScript
"
>
function myrefresh()
{
window.location.reload();
}
setTimeout(
'
myrefresh()
'
,
1000
);
//
指定1秒刷新一次
</
script
>
ASP.NET如何输出刷新父窗口脚本语句
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(''你要刷新的页.asp'');</script>
"
)
JS刷新框架的脚本语句
//
如何刷新包含该框架的页面用
<
script language
=
JavaScript
>
parent.location.reload();
</
script
>
//
子窗口刷新父窗口
<
script language
=
JavaScript
>
self.opener.location.reload();
</
script
>
( 或
<
a href
=
"
javascript:opener.location.reload()
"
>
刷新
</
a
>
)
//
如何刷新另一个框架的页面用
<
script language
=
JavaScript
>
parent.另一FrameID.location.reload();
</
script
>
如果想关闭窗口时刷新或者想开窗时刷新的话,在
<
body
>
中调用以下语句即可。
<
body onload
=
"
opener.location.reload()
"
>
开窗时刷新
<
body onUnload
=
"
opener.location.reload()
"
>
关闭时刷新
<
script language
=
"
javascript
"
>
window.opener.document.location.reload()
</
script
>
查看全文
相关阅读:
友链
CF496E Distributing Parts(贪心)题解
CF786C Till I Collapse(根号分治)题解
CF578B "Or" Game(贪心)题解
CF433C Ryouko's Memory Note(贪心)题解
Luogu4177 [CEOI2008]order(网络流)题解
骗分专辑
CF718A Efim and Strange Grade(贪心)题解
prufer序列--学习笔记
bzoj3450 Tyvj1952 Easy(期望DP)题解
原文地址:https://www.cnblogs.com/wubiyu/p/1081688.html
最新文章
利用策略模式与退化的建造模式实现减少工作量的方法
ceshi
《将博客搬至CSDN》
关于IIS中WEB网站访问弹“验证输入框”及“401限制访问”的解决办法
【转载】EFCodeFirst安装失败(包括EntityFrameWork安装),这样解决。。。
Tomcat实时监控,防止服务错误异常及当机,并自动重启修复。
为mysql数据库建立索引
如何避免JDBC内存溢出问题
最简单js控制10秒后页面自动跳转
清除eclipse 里面主函数的加载记录 launch configuration删除
热门文章
《将博客搬至CSDN》
SQL数据库与treeview的简单链接
Listview与imageList联动使用
第四章4.2-4.9和4.12
窗体控件第4单元
窗体控件11-20总结
窗体工具习题1-10总结
C#窗体工具习题
题
.net第一章总结
Copyright © 2011-2022 走看看