仿百度搜索

domain层:

package com.itheima.domain;

public class Word {
    private int id;
    private String word;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getWord() {
        return word;
    }
    public void setWord(String word) {
        this.word = word;
    }
}

Dao层:

package com.itheima.dao;

import java.sql.SQLException;
import java.util.List;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;

import com.itheima.domain.Word;
import com.itheima.utils.JDBCUtils;

public class WordDao {

    public List<Word> getWord(String word) throws SQLException {
        QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource());
        String sql = "select * from words where word like ? limit 5";
        List<Word> list = queryRunner.query(sql, new BeanListHandler<Word>(Word.class), word+"%");
        return list;
    }

}

service业务层:

package com.itheima.service;

import java.sql.SQLException;
import java.util.List;

import com.itheima.dao.WordDao;
import com.itheima.domain.Word;

public class WordService {

    public List<Word> getWord(String word) throws SQLException {
        WordDao wordDao = new WordDao();
        List<Word> list = wordDao.getWord(word);
        return list;
    }

}

Servlet层:

package com.itheima.servlet;

import java.io.IOException;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.itheima.domain.Word;
import com.itheima.service.WordService;

/**
 * 仿百度页面的Servlet
 */
public class BaiduSearchServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {
        try{
        //中文处理
        request.setCharacterEncoding("UTF-8");
        //接受参数
        String word = request.getParameter("word");
        //调用业务层处理数据
        WordService wordService = new WordService();
        List<Word> list = wordService.getWord(word);
        //将list存到request对象中
        request.setAttribute("list", list);
        //跳转页面
        request.getRequestDispatcher("/search/info.jsp").forward(request, response);
        }catch(Exception e){
            e.printStackTrace();
            throw new RuntimeException();
        }
    }

    protected void doPost(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

Utils:

package com.itheima.utils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.sql.DataSource;

import com.mchange.v2.c3p0.ComboPooledDataSource;

/**
 * JDBC的工具类
 * 
 * @author jt
 * 
 */
public class JDBCUtils {
    // 创建一个连接池:但是这个连接池只需要创建一次即可。
    private static final ComboPooledDataSource dataSource = new ComboPooledDataSource();

    /**
     * 获得连接的方法
     * 
     * @throws SQLException
     */
    public static Connection getConnection() throws SQLException {
        return dataSource.getConnection();
    }

    /**
     * 获得连接池:
     */
    public static DataSource getDataSource() {
        return dataSource;
    }

}

需要导入jquery-1.8.3.js文件;
jar包:
c3p0-0.9.1.2.jar
commons-dbutils-1.4.jar
fastjson-1.2.9.jar
jstl.jar
mysql-connector-java-5.0.8-bin.jar
standard.jar
xpp3_min-1.1.4c.jar
xstream-1.4.4.jar
还需要:search.js文件
前端页面;
info.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<html>
<head>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
</head>
<body>
    <table border="1" style="width: 100%; margin-left: 380px">
        <c:forEach var="w" items="${list}">
            <tr>
                <td>${w.word}</td>
            </tr>
        </c:forEach>
    </table>
</body>
</html>

search.jsp页面:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!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>Insert title here</title>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-1.8.3.js"></script>
<script type="text/javascript" src="${pageContext.request.contextPath}/search/search.js"></script>
</head>
<body>
    <center>
        <h1>百度一下</h1>
        <input type="text" id="word" name="word"
            style="width: 500px; height: 18px"> <input type="button"
            value="百度一下"><br>
        <div id="d1"
            style="display: none; position: absolute; border: 1px solid grey; width: 500px; height: 20px">
        </div>

    </center>
</body>
</html>

简单的实现了一下仿百度搜索时的离焦事件,自己瞎捉摸的,有兴趣的可以看一下

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值