广

Java编程

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

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

    2018-11-09 09:49:17 次阅读 稿源:互联网
    零七广告
    在项目中,经常会遇到页面分割,最常见的系统或网站的主界面。主页面分为,上面系统简介、下面作者简介、左边系统功能菜单、右边则是菜单真正展示的界面。

    遇到这种这种分割页面,大家首先想到是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("从后台传入的数据");

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

    零七网部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与零七网进行文章共享合作。

    零七广告
    零七广告
    零七广告
    零七广告