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

   
       在项目中,经常会遇到页面分割,最常见的系统或网站的主界面。主页面分为,上面系统简介、下面作者简介、左边系统功能菜单、右边则是菜单真正展示的界面。
       
      遇到这种这种分割页面,大家首先想到是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="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【刷新某个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("从后台传入的数据");
          
           两种刷新方式,一种整体刷新;一种局部刷新;
           
 
           
  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值