整体刷新和局部刷新frameset窗口

摘要:
当您遇到这种拆分页面时,首先想到的是框架集,这是拆分多个框架的简单方法。如果你不喜欢使用framset,喜欢前景设计的人可能会选择使用div拼接和浮动,这将考验css风格的强度。这次我们将主要讨论部分刷新的问题。现在使用帧集分割两个帧并分别更新它们。它对左侧帧没有影响。实际上,它是从数据库中重新读取数据˂FRAMESRC=“http://t.zoukankan.com/modifyMenu ! 在右侧页面提交RightFrame时,使用JS更新左侧的LeftFrame。说到部分刷新,您必须想到Ajax部分刷新。

在项目中,经常会遇到页面分割,最常见的系统或网站的主界面。主页面分为,上面系统简介、下面作者简介、左边系统功能菜单、右边则是菜单真正展示的界面。
遇到这种这种分割页面,大家首先想到是frameset,使用framset分割多种frame,这种方式简单。若是不喜欢使用framset,喜欢前台设计的人也许会选择div拼接,浮动,这就考查css样式的功底了。

这次主要讲解局部刷新的问题。需求是:左边frame,右边frame。
大家肯定疑问,这样刷新没有问题啊。的确如此。现在使用framset,分割两frame,各自更新各自。右边frame展示菜单尽管更新提交即可。对左边frame是没有影响的。
为了方便理解,左边Frame简称LeftFrame,右边Frame简称RightFrame;假如我提交RightFrame页面,需要更新LeftFrame【动态】页面。那如何办呢?
其实就是从数据库中重新读数据;

<FRAMESET cols = "280,*" frameborder=yes bordercolor=silver>
<FRAME SRC="http://t.zoukankan.com/modifyMenu!showTreeMenu" NAME="menuTree" SCROLLING="No" id="leftTree">
<FRAME SRC="http://t.zoukankan.com/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【刷新某个div】。

提到局部部分刷新,肯定想到是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获得左边页面中的某一个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中的写法如下:
HttpServletResponse response=ServletActionContext.getResponse();
response.setContentType("text/html;charset=utf-8");
out=response.getWriter();
out.print("从后台传入的数据");
两种刷新方式,一种整体刷新;一种局部刷新;

免责声明:文章转载自《整体刷新和局部刷新frameset窗口》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Web API(二):Web API概述Fake SQL Tuning, v$session, etc...下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

element-ui表格el-table回显时默认全选数据

1、html代码˂el-table-columntype="selection"width="45"...

seata启动报错的可能原因,以及解决方案

seata启动错误的可能原因及解决方案。首先,我下载了seata 0.9版和jdk 12.0.2版。启动错误的截图是:它显示无法创建虚拟机。我尝试了很多方法,但都没有解决。...

postman点击一次连续发送多次请求

可以测试同一个时间点创建订单。因为在工作中遇到的以此记录下,在工作上遇到同一个时间点产生了相同的赛时单号。...

Tomcat和JDK版本的对应关系

当我们讨论Tomcat和JDK版本之间的对应关系时,我们实际上讨论了两个问题。对于第一个问题,您可以通过官方网站上的图的最后一列获得答案:因此,如果您安装Tomcat 7,则需要安装JDK1.6和更高版本才能正常启动Tomcat。对于第二个问题,我们应该明确第一个问题和第二个疑问有相同的基本答案:低版本JDK不能运行高版本JDK编译的代码。因此,如果您安装T...

java 符号引用与直接引用

运行一次后,符号引用将替换为直接引用,下次不需要搜索。直接引用是偏移。通过偏移量,虚拟机可以直接找到该类内存区域中方法字节码的起始位置。可以看到,类文件中invokevirtual指令的操作数在经过几层间接寻址后都由字符串表示。这是Class文件中“符号引用”的真实状态:具有类型/结构的字符串。...

halo项目源码本地部署解决方案

找不到build-info.properties文件(运行时)Beanmethod'buildProperties'in'ProjectInfoAutoConfiguration'notloaded@ConditionalOnResourcedidnotfindresource'${spring.info.build.location:classpath:M...