整体刷新和局部刷新frameset窗口问题深入探讨

 更新时间:2013年04月07日 16:58:36   作者:  
页面分割,最常见的系统或网站的主界面,到这种这种分割页面,大家首先想到是frameset,使用framset分割多种frame,这种方式简单,接下来为大家介绍下局部刷新的问题
在项目中,经常会遇到页面分割,最常见的系统或网站的主界面。主页面分为,上面系统简介、下面作者简介、左边系统功能菜单、右边则是菜单真正展示的界面。

遇到这种这种分割页面,大家首先想到是frameset,使用framset分割多种frame,这种方式简单。若是不喜欢使用framset,喜欢前台设计的人也许会选择div拼接,浮动,这就考查css样式的功底了。
这次主要讲解局部刷新的问题。需求是:左边frame,右边frame。

大家肯定疑问,这样刷新没有问题啊。的确如此。现在使用framset,分割两frame,各自更新各自。右边frame展示菜单尽管更新提交即可。对左边frame是没有影响的。

为了方便理解,左边Frame简称LeftFrame,右边Frame简称RightFrame;假如我提交RightFrame页面,需要更新LeftFrame【动态】页面。那如何办呢?
其实就是从数据库中重新读数据;
复制代码 代码如下:

<FRAMESETcols="280,*"frameborder=yesbordercolor=silver>
<FRAMESRC="modifyMenu!showTreeMenu"NAME="menuTree"SCROLLING="No"id="leftTree">
<FRAMESRC="showModifyMenu.jsp"NAME="main"SCROLLING="AUTO"id="showModifyMenu">
lt;/FRAMESET>

其中modifyMenu!showTreeMenu是转向到tree.jsp页面
现在项目中,前台使用struts2,当提交右边页面数据时,当时设想:然后再次跳转到主界面,相当于重新读取数据,但是加载的主界面竟然是显示在右边区域,这样就成了两个LeftFrame。即使更改Struts2中的resultType的重定向也不可以。

最后,竟然一个简单的JS解决问题。
在提交右边页面RightFrame,使用JS更新左边LeftFrame。如下:
在rightFrame中的body的onload的事件:
复制代码 代码如下:

functioninit(){
//leftTree是左边Frame的id
//重新加载这个页面
window.parent.frames["leftTree"].location.reload();
}

window.parent.frames["leftTree"].location.reload()
当时你在某一个思路上山穷水尽的时候,可以尝试换种思路,也是会柳暗花明.
需求如下:若刷新右边RightFrame页面,只刷新部分左边LeftFrame【刷新某个div】。
提到局部部分刷新,肯定想到是Ajax局部刷新。
那我们用纯js的Ajax基础实现:
复制代码 代码如下:

functioncreateXmlHttpRequest(){
if(window.XMLHttpRequest){
returnnewXMLHttpRequest();
}elseif(window.ActiveXObject){
returnnewActiveXObject("Microsoft.XMLHTTP");
}
}
functioninit(){
//则进行局部刷新
varxmlHttpReq=createXmlHttpRequest();
//获得出发的url的,比如struts2的action或者servlet或jsp页面
varurl="success.jsp";
xmlHttpReq.open("GET",url,true);
//因为你在作一个异步调用,
//所以你需要注册一个XMLHttpRequest对象将调用的回调事件处理器
xmlHttpReq.onreadystatechange=function(){
if(xmlHttpReq.readyState==4){
if(xmlHttpReq.status==200){
//使用parent获得左边页面中的某一个div,然后更改展示的外观
window.parent.frames["leftTree"].document.getElementById(divId).innerHTML="测试";
}else{
alert(xmlHttpReq.status+xmlHttpReq.responseText);
}
}
};
xmlHttpReq.send(null);
}

window.parent.frames["leftTree"].document.getElementById(divId).innerHTML=xmlHttpReq.responseText
后台action中的写法如下:
复制代码 代码如下:

01.HttpServletResponseresponse=ServletActionContext.getResponse();
response.setContentType("text/html;charset=utf-8");
out=response.getWriter();
out.print("从后台传入的数据");

两种刷新方式,一种整体刷新;一种局部刷新;

相关文章

  • JSP+jquery使用ajax方式调用json的实现方法

    JSP+jquery使用ajax方式调用json的实现方法

    这篇文章主要介绍了JSP+jquery使用ajax方式调用json的实现方法,以实例形式较为详细的分析了前台Ajax调用及后台JSP的处理技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • hibernate更新数据方法小结

    hibernate更新数据方法小结

    session.update不能直接用,因为他是以ID为主键,必须查询出ID才能进行更新。。。
    2008-11-11
  • JSP 开发之THE SERVLET NAME ALREADY EXISTS.解决方法

    JSP 开发之THE SERVLET NAME ALREADY EXISTS.解决方法

    这篇文章主要介绍了JSP 开发之THE SERVLET NAME ALREADY EXISTS.解决方法的相关资料,希望通过本文大家能解决这样的问题,需要的朋友可以参考下
    2017-09-09
  • 如何在jsp界面中插入图片

    如何在jsp界面中插入图片

    这篇文章主要介绍了如何在jsp界面中插入图片,文章通过示例代码和运行结果图介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 一个简单的JAVA字符集过滤器实现

    一个简单的JAVA字符集过滤器实现

    JAVA字符集过滤器函数代码
    2008-09-09
  • JSP导出Excel文件的方法

    JSP导出Excel文件的方法

    这篇文章主要介绍了JSP导出Excel文件的方法,涉及JSP表格操作及excel文件的生成技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • JSP 导出Excel表格的实例

    JSP 导出Excel表格的实例

    下面小编就为大家带来一篇JSP 导出Excel表格的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 实例讲解JSP获取ResultSet结果集中的数据的方法

    实例讲解JSP获取ResultSet结果集中的数据的方法

    这篇文章主要介绍了JSP获取ResultSet结果集中数据的方法,文后还介绍一种遍历ResultSet中的数据并转化为表格的方法,需要的朋友可以参考下
    2016-04-04
  • JSP实现快速上传文件的方法

    JSP实现快速上传文件的方法

    这篇文章主要介绍了JSP实现快速上传文件的方法,实例分析了JSP不使用第三方库实现快速上传文件的完整流程与相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • 详解Spring data 定义默认时间与日期的实例

    详解Spring data 定义默认时间与日期的实例

    这篇文章主要介绍了详解Spring data 定义默认时间与日期的实例的相关资料,这里提供实例帮助大家学习理解这部分内容,需要的朋友可以参考下
    2017-08-08

最新评论