有关于整体刷新和局部刷新frameset窗口

2016-02-19 10:36 20 1 收藏

下面图老师小编跟大家分享一个简单易学的有关于整体刷新和局部刷新frameset窗口教程,get新技能是需要行动的,喜欢的朋友赶紧收藏起来学习下吧!

【 tulaoshi.com - 编程语言 】

在项目中,经常会遇到页面分割,最常见的系统或网站的主界面。主页面分为,上面系统简介、下面作者简介、左边系统功能菜单、右边则是菜单真正展示的界面。

遇到这种这种分割页面,大家首先想到是frameset,使用framset分割多种frame,这种方式简单。若是不喜欢使用framset,喜欢前台设计的人也许会选择p拼接,浮动,这就考查css样式的功底了。

这次主要讲解局部刷新的问题。需求是:左边frame,右边frame。

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

为了方便理解,左边Frame简称LeftFrame,右边Frame简称RightFrame;假如我提交RightFrame页面,需要更新LeftFrame页面。那如何办呢?

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

其实就是从数据库中重新读数据;

代码如下:

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。如下:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

在rightFrame中的body的onload的事件:

代码如下:

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

window.parent.frames[ "leftTree"].location.reload()

当时你在某一个思路上山穷水尽的时候,可以尝试换种思路,也是会柳暗花明.

需求如下:若刷新右边RightFrame页面,只刷新部分左边LeftFrame。

提到局部部分刷新,肯定想到是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("从后台传入的数据");

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

来源:http://www.tulaoshi.com/n/20160219/1595195.html

延伸阅读
标签: Web开发
通过XMLHTTP发送请求,返回结果. scriptlanguage="JavaScript" functionGetResult() ...{ /**//**//**//* *---------------GetResult()----------------- *GetResult() *功能:通过XMLHTTP发送请求,返回结果. *参数:str,字符串,发送条件. *实例:GetResult(); ...
标签: Web开发
--------------就是下面这个很简单的javascript函数SEND(STR,URL)---------------------- 使用到的是XMLDOM和XMLHTTP对象.用这种技术的好处是:全JS控制,方便/简单,比RDS 或者remote好多了.(前提:服务器端和客户端都必须安装IE5或者更高版本) function Send(Str,URL) //STR参数是传入的XML数据,你也可以传入其他文本数据. //不过这个函数需...
photoshop绘制精致刷新按钮 TuLaoShi.com 效果图 制作教程
标签: Web开发
通过XMLHTTP发送请求,返回结果.   script language="JavaScript" function GetResult() ...{ /**//**//**//* *--------------- GetResult() ----------------- * GetResult() * 功能:通过XMLHTTP发送请求,返回结果. * 参数:str,字符串,发送条件. * 实例:GetResult(); *--------------- GetResult() ----------------- */ v...
标签: Web开发
script language="JavaScript" //禁止刷新,回退 function onKeyDown() { if ( (event.altKey) || ((event.keyCode == 8) && (event.srcElement.type != "text" && event.srcElement.type != "textarea" && event.srcElement.type != "password")...

经验教程

970

收藏

22
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部