jQuery框架+DWR框架实现的Java Web中的Ajax效果(异步请求,局部刷新)

简介:

一 简介和实现效果

这里用一个小例子来简单举例说明,做一个搜索引擎搜索提示效果,通过不断输入字符,然后在下方给出搜索提示。效果图如下:

wKioL1ZZSd-BXabpAAEBh395zLw764.png

wKiom1ZZSX6QmExoAACAJbOFSZs407.png

通过上图可以看到,当输入一个“a”时,提示了很多内容,然后继续输入一个“e”后,提示的范围明显就变小了。

注:在文末我会给出完整源代码的下载链接,以供大家参考


二 具体实现

1 在eclipse for java ee中创建一个Java Web工程,然后导入相应的jar包,特别说明的是:这里要导入一个额外的dwr.jar。也就是说,如果在Struts2工程中,除了要导入Struts2相关的jar包外,还要导入一个dwr.jar。可以自行在网上下载,也可以通过文末的下载链接下载。

2 配置好数据库连接,连接MySQL中的“mysql”这个库来做测试,并定义一个方法getKeyWord(String key),以供我们待会调用,目的是给定一个字符串,然后在“help_keyword”这个表中进行模糊查询,然后返回结果。

DbConn.java:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package  com.dao;
 
import  java.sql.Connection;
import  java.sql.PreparedStatement;
import  java.sql.ResultSet;
import  java.sql.SQLException;
 
import  javax.naming.InitialContext;
import  javax.sql.DataSource;
 
public  class  DbConn {   
     /**
      * 通过JNDI连接池的方式
      * */
     public  static  Connection getConnection(){
         try  {         
             InitialContext context =  new  InitialContext();
             DataSource dSource = (DataSource) context.lookup( "java:comp/env/jdbc/mysql" );
             Connection conn = dSource.getConnection();
             
             return  conn;                      
         catch  (Exception e) {        
             e.printStackTrace();
         }      
         return  null ;
     }
     
     public  String getKeyWord(String key){
         Connection connection = getConnection();
         try  {
             PreparedStatement preparedStatement = connection.prepareStatement( "select name from help_keyword where name like ?" );
             preparedStatement.setString( 1 , key +  "%" );
             ResultSet resultSet = preparedStatement.executeQuery();
             
             StringBuffer stringBuffer =  new  StringBuffer();
             while (resultSet.next())
                 stringBuffer.append(resultSet.getString( 1 ) +  "<br>" );
 
             resultSet.close();
             connection.close();   //不关的话,在JNDI模式下查询10次以后就会被卡死
             return  stringBuffer.toString();       
         catch  (SQLException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }
         return  "" ;
     }
}

help_keyword这个表:

wKioL1ZZSiWQ99WCAAGeSjYnNZA930.png

3 定义一个Action “KeyAction.java”,主要是定义了一个方法“getName(String key)”,用于调用dao层的数据库操作,返回查询到的数据,同时这个方法也被我们前台调用,然后取得数据并显示。(PS:业务逻辑层biz省略了)

KeyAction.java:

1
2
3
4
5
6
7
8
9
10
11
12
13
package  com.action;
 
import  com.dao.DbConn;
import  com.opensymphony.xwork2.ActionSupport;
 
public  class  KeyAction  extends  ActionSupport {
     private  static  final  long  serialVersionUID = 1L;
 
     public  String getName(String key) throws  Exception{
         DbConn dbConn =  new  DbConn();
         return  dbConn.getKeyWord(key);
    
}

4 配置DWR框架


(1)在web.xml中增加如下节点:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<!-- dwr -->
   < servlet >
       < servlet-name >dwr-invoker</ servlet-name >
       < servlet-class >org.directwebremoting.servlet.DwrServlet</ servlet-class >
     < init-param >
         < param-name >debug</ param-name >
         < param-value >false</ param-value >   
     </ init-param >
   </ servlet >
   
   < servlet-mapping >
       < servlet-name >dwr-invoker</ servlet-name >
       < url-pattern >/dwr/*</ url-pattern >
   </ servlet-mapping >

(2)在web.xml同目录下新建DWR配置文件:dwr.xml(PS:WebContent/WEB-INF/dwr.xml)。特别说明的是,这里的new表示每次调用都用新建的方式;javascript这个参数是指定一个实例化名称,可以随意命名,但是要和前台的JavaScript里相对应。method这个参数是指调用com.action.KeyAction这个类中的哪个方法,我们这里当时是“getName”


dwr.xml:

1
2
3
4
5
6
7
8
9
10
<? xml  version = "1.0"  encoding = "UTF-8" ?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN" "http://directwebremoting.org/dwr/dwr30.dtd">
< dwr >
     < allow >
         < create  creator = "new"  javascript = "KeyWord" >
             < param  name = "class"  value = "com.action.KeyAction" ></ param >
             < include  method = "getName" />
         </ create >
     </ allow >
</ dwr >

5 前台调用,新建一个index.jsp,用于显示效果。其中有一些简单的jQuery语法,具体细节可自行参考W3School,注意的是,JavaScript中的“KeyWord.getName(key,callBack);”才是进行数据异步传送的关键,通过KeyWord实例调用getName()方法取得的数据被函数callBack获得,然后再将相关数据写入页面中,实现页面局部刷新


index.jsp:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<%@ page language="java" contentType="text/html; charset=UTF-8"
     pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE html>
< html >
< head >
< meta  http-equiv = "Content-Type"  content = "text/html; charset=UTF-8" >
     < base  href="<%=basePath%>">
     < title >Struts2 Ajax Google</ title >
     < script  type = 'text/javascript'  src = 'dwr/engine.js' ></ script >
    < script  type = 'text/javascript'  src = 'dwr/interface/KeyWord.js' '></ script >
    < script  type = "text/javascript"  src = "js/jquery-1.11.3.min.js" ></ script >
    < script  type = "text/javascript" >
        $(document).ready(function(){
            $("#search").keyup(function(){
                var key = $("#search").val();
                KeyWord.getName(key,callBack);
            });
            function callBack(data){                  
                $("#result").html("< b >" + data + "</ b >");
            }
        });
    
    </ script >
</ head >
< body >
     < div  align = "center" >
         < img  src = "img/logo.jpg"  style = "padding-top:58px;height:350px;width:650px;" >< br >< br >
         < input  type = "text"  id = "search"  style = "width:600px;height:38px;font-size:20px;font-weight:bold;" >
         < input  type = "button"  id = "sub"  value = "Google 搜索"  style = "height:40px;" >< br >
         
         < div  id = "result" ></ div >
     </ div >
</ body >
</ html >


三 测试

wKiom1ZZSkiAQfrwAAFhayCU3DQ092.png



本文转自 pangfc 51CTO博客,原文链接:http://blog.51cto.com/983836259/1717724,如需转载请自行联系原作者

相关文章
|
13天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
31 6
|
13天前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
30 3
|
13天前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
26 2
|
2天前
|
人工智能 前端开发 Java
基于开源框架Spring AI Alibaba快速构建Java应用
本文旨在帮助开发者快速掌握并应用 Spring AI Alibaba,提升基于 Java 的大模型应用开发效率和安全性。
基于开源框架Spring AI Alibaba快速构建Java应用
|
2天前
|
消息中间件 Java 数据库连接
Java 反射最全详解 ,框架设计必掌握!
本文详细解析Java反射机制,包括反射的概念、用途、实现原理及应用场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
Java 反射最全详解 ,框架设计必掌握!
|
10天前
|
前端开发 Java 数据库连接
Spring 框架:Java 开发者的春天
Spring 框架是一个功能强大的开源框架,主要用于简化 Java 企业级应用的开发,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,并由Pivotal团队维护。
31 1
Spring 框架:Java 开发者的春天
|
8天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
4天前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
7 1
|
10天前
|
Java 数据库连接 开发者
Spring 框架:Java 开发者的春天
【10月更文挑战第27天】Spring 框架由 Rod Johnson 在 2002 年创建,旨在解决 Java 企业级开发中的复杂性问题。它通过控制反转(IOC)和面向切面的编程(AOP)等核心机制,提供了轻量级的容器和丰富的功能,支持 Web 开发、数据访问等领域,显著提高了开发效率和应用的可维护性。Spring 拥有强大的社区支持和丰富的生态系统,是 Java 开发不可或缺的工具。
|
10天前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
38 5