Ajax

 

 Ajax 省市区三级联动

JSP

<%--
  Created by IntelliJ IDEA.
  User: QuietHR
  Date: 2018/8/26
  Time: 11:26
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>三级联动</title>
    <script type="text/javascript" src="js/jquery-1.11.3.min.js"></script>
    <script type="text/javascript">

       $(function () {
           //初始化省信息
           $.ajax({
                    type:"post",
                    url:"${pageContext.request.contextPath}/PCDListServlet",
                    data:"pid=-1",
                    success:function (provinceJson) {
                        var province_str="<option value='null'>--请选择省--</option>";
                        $(provinceJson).each(function () {
                            var id = this.id;
                            var name = this.name;
                            province_str += "<option value='"+ id +"'>"+ name +"</option>";
                        })
                        $("#province").html(province_str);
                    }
               }
           );

           //省改变时 加载市信息
           $("#province").change(function () {
               var province_id = this.value;
               $("#district").html("<option value='null'>--请选择区县--</option>");

               $.post(
                   "${pageContext.request.contextPath}/PCDListServlet",
                   {"pid":province_id},
                    function (cityJson) {
                       var city_str="<option value='null'>--请选择市--</option>";
                        $(cityJson).each(function () {
                            var id = this.id;
                            var name = this.name;
                            city_str += "<option value='"+ id +"'>"+ name +"</option>";
                        })
                        $("#city").html(city_str);
                    }
               );

           });

           //市改变时 加载区县信息
           $("#city").change(function () {
               var city_id = this.value;

               $.get(
                   "${pageContext.request.contextPath}/PCDListServlet",
                   {"pid":city_id},
                   function (districtJson) {
                       var district_str="<option value='null'>--请选择区县--</option>";
                       $(districtJson).each(function () {
                           var id = this.id;
                           var name = this.name;
                           district_str += "<option value='"+ id +"'>"+ name +"</option>";
                       })
                       $("#district").html(district_str);
                   }
               )
           });

       });



    </script>
</head>
<body>

    <select id="province">
        <option value="null">--请选择省--</option>
    </select>

    <select id="city">
        <option value="null">--请选择市--</option>
    </select>

    <select id="district">
        <option value="null">--请选择区县--</option>
    </select>
</body>
</html>

 web层

package com.hrh.web;

import com.hrh.domain.PCD;
import com.hrh.service.PCDService;
import flexjson.JSONSerializer;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;

public class PCDListServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

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

        int pid = Integer.parseInt(request.getParameter("pid"));
        PCDService pcdService=new PCDService();
        List<PCD> pcdList=pcdService.findAll(pid);
        System.out.println(pcdList);
        response.setContentType("application/json;charset=utf-8");
        String json = new JSONSerializer().exclude("*.class").serialize(pcdList);
        response.getWriter().print(json);
    }
}

 service层

package com.hrh.service;

import com.hrh.dao.PCDDao;
import com.hrh.domain.PCD;

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

public class PCDService {
    public List<PCD> findAll(int pid) {
        PCDDao pcdDao=new PCDDao();
        List<PCD> pcdList= null;
        try {
            pcdList = pcdDao.findAll(pid);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return pcdList;
    }
}

 dao层

package com.hrh.dao;

import com.hrh.domain.PCD;
import com.hrh.utils.JDBCUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;

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

public class PCDDao {
    public List<PCD> findAll(int pid) throws SQLException {
        QueryRunner queryRunner=new QueryRunner(JDBCUtils.getDataSource());
        String sql="select * from province_city_district where pid=?";
        List<PCD> pcdList = queryRunner.query(sql, new BeanListHandler<>(PCD.class), pid);
        return pcdList;
    }
}

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值