AJAX(prototype)实现的局部刷新搜索框实例

 

AJAX是个老话题了,传统的web应用允许用户填写表单(form),当提交表单时就向web服务器发送一个请求。服务器接收并处理传来的表单,然后返回一个新的网页。这个做法浪费了许多带宽,因为在前后两个页面中的大部分HTML代码往往是相同的。由于每次应用的交互都需要向服务器发送请求,应用的响应时间就依赖于服务器的响应时间。这导致了用户界面的响应比本地应用慢得多。
  
  与此不同,AJAX应用可以仅向服务器发送并取回必需的数据,它使用SOAP或其它一些基于XML的web service接口,并在客户端采用JavaScript处理来自服务器的响应。因为在服务器和浏览器之间交换的数据大量减少,结果我们就能看到响应更快的应用。同时很多的处理工作可以在发出请求的客户端机器上完成,所以Web服务器的处理时间也减少了。
不说那么多废话了,直接入题:
首先,写jsp页面:
< %@ page  language ="java"  contentType ="text/html; charset=UTF-8"  pageEncoding ="UTF-8"% >
< %@ taglib  prefix ="ww"  uri ="/webwork" % >
<%
    String path=request.getContextPath();
%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd" >
< html >
< head >
< meta  http-equiv ="Content-Type"  content ="text/html; charset=UTF-8" >
< title >TimeCard Manager Platform </title>
< script src="<%=path% >/js/prototype.js"> </script>
     < script >
      function getXML(){
      / /局部请求地址
      var url="searchAction.action";
       //获取用户当前输入的内容
      var inputvalue=document.getElementById("itext").value;
       //使用prototype函数构造xmlhttprequest对象
      var myAjax = new Ajax.Request(
      url,
      {
           //请求方法为post
          method:'post',
           //设置参数为 inputtext=inputtext
          parameters:"inputtext="+inputvalue,
           //设置回调函数
          onComplete:showResponse,
           //是否异步
          asynchronous:true
      }
      );
      }
      function showResponse(xmlrequest){
        //回调函数
       var text = xmlrequest.responseText;
        //将匹配的内容输出到 span 层
       document.getElementById("projectspan").innerHTML=text;
        // $("projectspan").innerHTML=xmlrequest.responseText;
       }
</head>
< body >
Project manager:
     < span  id ="projectspan"  class ="font_bluet" > <select
    name="project.resource_id" id="prijectmanager">
      < option  value ="-1" > Choose </option>
      < option  value ="0"  >aaaa </option>
      < option  value ="1"  >bbbb </option>
      < option  value ="2"  >cccc </option>
      < option  value ="3"  >dddd </option>
     </select>  </span>
     < input  name ="text"  type ="text"  id ="itext"  onKeyUp ="getXML()"  />
</body>
</html>

在XWORK.XML中加入下面的代码:
< action  name ="searchAction"  method ="searchAction"     class ="com.mdcl.timecard.action.ProjectAction"  >
</ action >

在action中:
public  void searchAction() {

HttpServletResponse   response=ServletActionContext.getResponse();  
                      
 response.setContentType( "text/html;charset=utf-8");

 PrintWriter out;

String inputtext = ServletActionContext.getRequest().getParameter("inputtext"); 
 
   //根据输入框的内容到数据库查询符合条件项,返回
  // List (
resourcelist1)
   //如果没有符合条件项,则查询所有列表,返回  List ( resourcelist)
   if(!resourcelist1.isEmpty() || resourcelist1.size()>0){
   try {
      out = ServletActionContext.getResponse().getWriter();
      out.println( "<select name='project.resource_id' id='prijectmanager' class='fram'>");
       for( int i=0;i<resourcelist1.size();i++){
    out.println( "<option value=" + resourcelist1.get(i).getResourceId() +  ">"
      + resourcelist1.get(i).getName() +  "</option>");
    
      }
      out.println( "</select>");
       //输出缓存字符串
        
         out.flush();
         out.close();
      
  }  catch (IOException e) {
       // TODO Auto-generated catch block
      e.printStackTrace();
  }
  } else{
       try {
    out = ServletActionContext.getResponse().getWriter();
    out.println( "<select name='project.resource_id' id='prijectmanager' class='fram'>");
     for( int i=0;i<resourcelist.size();i++){
        out.println( "<option value=" + resourcelist.get(i).getResourceId() +  ">"
          + resourcelist.get(i).getName() +  "</option>");
        
    }
    out.println( "</select>No Information!");
     //输出缓存字符串
         
          out.flush();
          out.close();
    
      }  catch (IOException e) {
     // TODO Auto-generated catch block
    e.printStackTrace();
      }
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值