有关于整体刷新和局部刷新frameset窗口
遇到这种这种分割页面,大家首先想到是frameset,使用framset分割多种frame,这种方式简单。若是不喜欢使用framset,喜欢前台设计的人也许会选择p拼接,浮动,这就考查css样式的功底了。
这次主要讲解局部刷新的问题。需求是:左边frame,右边frame。
大家肯定疑问,这样刷新没有问题啊。的确如此。现在使用framset,分割两frame,各自更新各自。右边frame展示菜单尽管更新提交即可。对左边frame是没有影响的。
为了方便理解,左边frame简称leftframe,右边frame简称rightframe;假如我提交rightframe页面,需要更新leftframe【动态】页面。那如何办呢?
其实就是从数据库中重新读数据;
<frameset cols = "280,*" frameborder=yes bordercolor=silver>
<frame src="modifymenu!showtreemenu" name="menutree" scrolling="no" id="lefttree">
<frame src="showmodifymenu.jsp" name="main" scrolling="auto" id="showmodifymenu">
</frameset>
其中modifymenu!showtreemenu是转向到tree.jsp页面
现在项目中,前台使用struts2,当提交右边页面数据时,当时设想:然后再次跳转到主界面,相当于重新读取数据,但是加载的主界面竟然是显示在右边区域,这样就成了两个leftframe。即使更改struts2中的resulttype的重定向也不可以。
最后,竟然一个简单的js解决问题。
在提交右边页面rightframe,使用js更新左边leftframe。如下:
在rightframe中的body的onload的事件:
function init(){
//lefttree是左边frame的id
//重新加载这个页面
window.parent.frames[ "lefttree"].location.reload();
}
window.parent.frames[ "lefttree"].location.reload()
当时你在某一个思路上山穷水尽的时候,可以尝试换种思路,也是会柳暗花明.
需求如下:若刷新右边rightframe页面,只刷新部分左边leftframe【刷新某个p】。
提到局部部分刷新,肯定想到是ajax局部刷新。
那我们用纯js的ajax基础实现:
function createxmlhttprequest(){
if(window.xmlhttprequest){
return new xmlhttprequest();
}else if(window.activexobject){
return new activexobject("microsoft.xmlhttp");
}
}
function init(){
//则进行局部刷新
var xmlhttpreq=createxmlhttprequest();
//获得出发的url的,比如struts2的action或者servlet或jsp页面
var url="success.jsp";
xmlhttpreq.open("get",url,true);
//因为你在作一个异步调用,
//所以你需要注册一个xmlhttprequest对象将调用的回调事件处理器
xmlhttpreq.onreadystatechange=function(){
if(xmlhttpreq.readystate==4){
if(xmlhttpreq.status==200){
//使用parent获得左边页面中的某一个p,然后更改展示的外观
window.parent.frames["lefttree"].document.getelementbyid(pid).innerhtml="测试";
}else{
alert(xmlhttpreq.status+xmlhttpreq.responsetext);
}
}
};
xmlhttpreq.send(null);
}
window.parent.frames["lefttree"].document.getelementbyid(pid).innerhtml=xmlhttpreq.responsetext
后台action中的写法如下:
httpservletresponse response=servletactioncontext.getresponse();
response.setcontenttype("text/html;charset=utf-8");
out=response.getwriter();
out.print("从后台传入的数据");
两种刷新方式,一种整体刷新;一种局部刷新;