有关于用java实现ajax的省市联动

本文详细介绍了如何使用Java和Ajax实现省市联动效果。首先展示了一个包含省市区选择的JSP页面,通过Ajax调用DAO层获取省市区数据。在DAO层中,使用jdbc连接数据库,查询省市区信息。在JavaScript部分,展示了创建XMLHttpRequest对象,发送请求并处理响应的代码。整个过程涉及数据库连接、SQL查询、XMLHttpRequest的使用以及Servlet的交互。
摘要由CSDN通过智能技术生成

ajax这种东西自己不想说了  百度一下有很多  写这个也是感觉做这个复习了很多知识  有必要记录一下(本人只是实习生一枚)

首先要写一个jsp(其实也是找了很多资料才完成的)

<%@ page language="java" import="java.util.*,com.dao.*,com.vo.*" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%   //这个是调用dao层返回省表中的内容。
    UserDao ud=new UserDao();
    ArrayList<Sheng> list=(ArrayList)ud.select();
 %>
<!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>
<script type="text/javascript" src="js/test.js"></script>
</head>
<body>
  <form action="" method="post" name="form1">
    <select id="slt1" οnchange="updateSelect()">
      <option>请选择省份</option>
      <%
        Sheng sheng=null;
      for(int i = 0;i<list.size();i++){
          sheng=(Sheng)list.get(i);
      %>
      <option value="<%=sheng.getId()%>"><%=sheng.getName() %></option>
      <%
      }
      %>
    </select>
    <select id="slt2">
      <option value="">请选择城市</option>
    </select>
  </form>
</body>
</html>

这里首先需要在dao里找到sheng表中的信息,所以当然啦 还要建一个sheng的表,还要写一个jdbc连接数据库

连接数据库代码:public class DBUtil {
    
    /**
     * @return conn
     * @throws ClassNotFoundException ClassNotFoundException
     * @throws SQLException SQLException
     */
    public static Connection getConnection() throws ClassNotFoundException, SQLException {
        Connection conn = null;
        Class.forName("oracle.jdbc.driver.OracleDriver");// 实例化oracle数据库驱动程序(建立中间件)
        String url = "jdbc:oracle:thin:@localhost:1521:xe";// @localhost为服务器名,xe为数据库实例名
        conn = DriverManager.getConnection(url, "1", "2");// 连接数据库,1代表帐户,2代表密码
        
        return conn;
    }
    
}

实例名一点要找对!!!困扰我好久,数据库可直接查看!!!

再就是dao层代码:public ArrayList<Sheng> select() throws ClassNotFoundException,
        SQLException {
        Connection conn = DBUtil.getConnection();
        // 创建Statement
        Statement s = conn.createStatement();
        // 执行SQL语句
        String sql = "select * from sheng";
        // 处理结果集
        ResultSet rs = s.executeQuery(sql);
        ArrayList<Sheng> list = new ArrayList<Sheng>();
        while (rs.next()) {
            Sheng s1 = new Sheng();
            s1.setId(rs.getString("id"));
            s1.setName(rs.getString("name"));
            list.add(s1);
            
        }
        
        // 关闭
        rs.close();
        s.close();
        conn.close();
        return list;
        
    }这是查找sheng表中的数据

在jsp中通过

<%   //这个是调用dao层返回省表中的内容。
    UserDao ud=new UserDao();
    ArrayList<Sheng> list=(ArrayList)ud.select();
 %>找到

点击下拉框中的随便一个省,促发οnchange="updateSelect()"中的时间到js中

js代码:

//访问浏览器的设置  因为现在ie5.6基本不存在直接省略了那两个版本的XMLRequest
function getXmlHttpRequestObject() {
  if (window.XMLHttpRequest) {
    return new XMLHttpRequest();
  }
}
function createAjaxObj() {
  var httprequest = false;
  if (window.XMLHttpRequest) {
    httprequest = new XMLHttpRequest();
    if (httprequest.overrideMimeType) {
      httprequest.overrideMimeType("text/xml");
    }
  } else {
    if (window.ActionXObject) {
      try {
        httprequest = new ActionXObject("Msxml2.XMLHTTP");
      } catch (e) {
        try {
          httprequest = new ActiveXObject("Microsoft.XMLHTTP");
        } catch (e) {
        }
      }
    }
  }
  return httprequest;
}
var httpReq = createAjaxObj();

function updateSelect() {
  getXmlHttpRequestObject();
  var selected = document.all.slt1.value;
  httpReq.onreadystatechange = checkReqCallBack;
  httpReq.open("GET", "testU?tid=" + selected, true);
  httpReq.onreadystatechange = function() {
    checkReqCallBack();
  };
  httpReq.send(null);
}
function checkReqCallBack() {
  if (httpReq.readyState == 4) {
    if (httpReq.status == 200) {
      var xmlDoc = httpReq.responseXML.documentElement;// 获得返回的XML文档
      var xSel = xmlDoc.getElementsByTagName('select');// 获得XML文档中的所有<select>标记
      var select_root = document.getElementById('slt2');// 获得网页中的第二个下拉框
      select_root.options.length = 0; // 每次获得新的数据的时候先把每二个下拉框架的长度清0

      for (var i = 0; i < xSel.length; i++) {
        var xValue = xSel[i].childNodes[0].firstChild.nodeValue;// 获得每个<select>标记中的第一个标记的值,也就是<value>标记的值
        var xText = xSel[i].childNodes[1].firstChild.nodeValue;// 获得每个<select>标记中的第二个标记的值,也就是<text>标记的值

        var option = new Option(xText, xValue);// 根据每组value和text标记的值创建一个option对象

        try {
          select_root.add(option);// 将option对象添加到第二个下拉框中
        } catch (e) {
        }
      }
    } else {
      alert("不能得到描述信息:" + httpReq.statusText);
    }
  }
}

httpReq.open("GET", "testU?tid=" + selected, true);这句话是和servlet的连接  将得到的tid传给你的servlet,我的servlet叫TestU

servlet代码:package com.dao;

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

import com.tools.DBUtil;
import com.vo.Sheng;
import com.vo.Shi;

/**
 * UserDao
 */
public class UserDao {
    /**
     * @return list
     * @throws ClassNotFoundException ClassNotFoundException
     * @throws SQLException SQLException
     */
    public ArrayList<Sheng> select() throws ClassNotFoundException,
        SQLException {
        Connection conn = DBUtil.getConnection();
        // 创建Statement
        Statement s = conn.createStatement();
        // 执行SQL语句
        String sql = "select * from sheng";
        // 处理结果集
        ResultSet rs = s.executeQuery(sql);
        ArrayList<Sheng> list = new ArrayList<Sheng>();
        while (rs.next()) {
            Sheng s1 = new Sheng();
            s1.setId(rs.getString("id"));
            s1.setName(rs.getString("name"));
            list.add(s1);
            
        }
        
        // 关闭
        rs.close();
        s.close();
        conn.close();
        return list;
        
    }
    
    /**
     * @param tid tid
     * @return list
     * @throws ClassNotFoundException ClassNotFoundException
     * @throws SQLException SQLException
     */
    public ArrayList<Shi> check(String tid) throws ClassNotFoundException,
        SQLException {
        Connection conn = DBUtil.getConnection();
        // 创建Statement
        Statement s = conn.createStatement();
        // 执行SQL语句
        String sql = "select * from shi where id=" + tid;
        // 处理结果集
        ResultSet rs = s.executeQuery(sql);
        ArrayList<Shi> list = new ArrayList<Shi>();
        while (rs.next()) {
            Shi s1 = new Shi();
            s1.setId(rs.getString("id"));
            s1.setName(rs.getString("name"));
            list.add(s1);
            
        }
        
        // 关闭
        rs.close();
        s.close();
        conn.close();
        return list;
        
    }
    
}

采用的是xml解析方式将数据返还给js,但是接收到数据时,还需要调用dao层(至于web。xml中关于servlet的配置,就不说了,没有不会的吧)

dao层中市的查询:public ArrayList<Shi> check(String tid) throws ClassNotFoundException,
        SQLException {
        Connection conn = DBUtil.getConnection();
        // 创建Statement
        Statement s = conn.createStatement();
        // 执行SQL语句
        String sql = "select * from shi where id=" + tid;
        // 处理结果集
        ResultSet rs = s.executeQuery(sql);
        ArrayList<Shi> list = new ArrayList<Shi>();
        while (rs.next()) {
            Shi s1 = new Shi();
            s1.setId(rs.getString("id"));
            s1.setName(rs.getString("name"));
            list.add(s1);
            
        }
        
        // 关闭
        rs.close();
        s.close();
        conn.close();
        return list;
        
    }


js通过shi的id返还数据到jsp中就成功了


实现的截图就不发了  太简陋 不好意思发!

Java Ajax省市区三级联动是一种前端页面交互功能,用于在用户选择省份、城市和区县时实现动态加载相应数据的功能。 首先,需要在前端页面通过HTML代码创建三个下拉框,分别表示省份、城市和区县。然后,使用JavaScript编写前端的Ajax请求,通过发送异步请求到后端服务,获取数据。 在后端Java代码中,可以使用Spring MVC或Servlet等框架处理前端Ajax请求。首先,需要在数据库中建立相应的省市区数据表,并将数据存储在表中。然后,可以使用JDBC或MyBatis等数据库访问框架,编写相应的Java代码实现数据的查询和返回。 具体实现时,可以通过监听省份下拉框的变化事件,在事件处理函数内发送Ajax请求到后端服务,将当前选择的省份作为参数传递给后端。后端服务可以根据省份查询对应的城市数据,将城市数据返回给前端。 类似地,继续监听城市下拉框的变化事件,在事件处理函数内发送Ajax请求到后端服务,将当前选择的城市和省份作为参数传递给后端。后端服务可以根据城市和省份查询对应的区县数据,将区县数据返回给前端。 最后,根据返回的数据,在前端页面使用JavaScript动态修改区县下拉框的选项,实现三级联动效果。 总结起来,Java Ajax省市区三级联动通过前端页面的交互和后端的数据处理,实现了在用户选择省份、城市和区县时动态加载相应数据的功能。这种开发方式能够提高用户体验,同时满足实际业务需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值