zoukankan      html  css  js  c++  java
  • ajax 省市级联项目中的实现

    使用ajax实现省市联动,json做为数据的异常传输。项目S2SH

    • 加入json所依赖的jar包 

                

    •   编写查出所有的省的方法:

    /**** 到新增展会页面  */

    public String toAdd() {

    ActionContext context = ActionContext.getContext();

    HttpServletRequest request = (HttpServletRequest) context.get(ServletActionContext.HTTP_REQUEST);

    request.setAttribute("provinces", provinceService.findProvinces());// 查出所有的方法放到request中

    return "toAdd";

    }

    • 在页面中把所有的省都取出来

      <tr>

            <td class="title" width="150px;">举办省市</td>

     <td class="sep1" style="text-align: left;">

         <select  class="select" id="provinceId" onchange="changeProvince()" >

             <option value="1">请选择</option>

          <c:forEach items="${provinces}" var="province">

            <option value="${province.provinceId }">${province.provinceCnName}</option>

          </c:forEach>

            </select>

             <select name="cityName" class="select" id="cityId">

            <option value="1">请选择</option>

            </select>

         </td>

        </tr>

    • 编写ajax与后台交互,当省份发生改变解发onchange="changeProvince()"

           <script type="text/javascript">

    //改变省份

    function changeProvince(){

            var provinceId = document.getElementById("provinceId");

            sendAjaxRequest("actions/exhibitionAction!changeCity","provinceId="+provinceId.value,myback); //此方法己做封装可以到ajax学习去找

            };

         function myback()

         {

         clearList();

     if (xhr.readyState == 4) 

     { // 响应已完成

       if (xhr.status == 200)

        {// 成功处理

    var city = document.getElementById("cityId");

    var city2 =  JSON.parse(xhr.responseText);

        for(var i in city2)

        {  for(var j in city2[i])  {

         option=document.createElement("option");

         var cityCnName=document.createTextNode(city2[i][j].cityCnName);

         option.appendChild(cityCnName);

         option.setAttribute("value", city2[i][j].cityId);

         city.appendChild(option);

       

        }

    }

    }  

    }

         function clearList()

         {

         var departmentName=document.getElementById("cityId");

         while(departmentName.childNodes.length>0){

               departmentName.removeChild(departmentName.childNodes[0]);

             }

         }

      </script>

    • 编写changeCity方法在后台

           /**** 异步更改城市*/

    public String changeCity() {

    try {

    ActionContext context = ActionContext.getContext();

    HttpServletRequest request = (HttpServletRequest) context.get(ServletActionContext.HTTP_REQUEST);

    HttpServletResponse response = (HttpServletResponse) context.get(ServletActionContext.HTTP_RESPONSE);

    String cProvinceId = request.getParameter("provinceId");

    int provinceId = 0;

    List<City> listCitys = new ArrayList<City>();

    if (cProvinceId != null) {

    provinceId = Integer.valueOf(cProvinceId);

    listCitys = cityService.findCitysByProvinceId(provinceId);

    StringBuilder sb = new StringBuilder();

    sb.append("[[");

    int i = 1;

    for (City city : listCitys) {

    sb.append("{");

    sb.append("/"cityCnName/":/"").append(city.getCityCnName())

    .append("/",");

    sb.append("/"cityId/":").append(city.getCityId());

    sb.append("}");

    if (i != listCitys.size()) {

    sb.append(",");

    }

    i++;

    }

    sb.append("]]");

    System.out.println(sb.toString());

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

    response.getWriter().print(sb.toString());

    response.getWriter().flush();

    }

    } catch (Exception e) {

    e.printStackTrace();

    }

    return null;

    }

     

    效果图:

     

    注:后台的是自己拼写的json格式,[[{"cityCnName":"北京","cityId":1},{"cityCnName":"天津","cityId":2}]]

    我放一个JsonArray不行,所以自己拼写的。现在也不知道为什么,如有知道请赐教

  • 相关阅读:
    欧拉回路 定理
    UESTC 1087 【二分查找】
    POJ 3159 【朴素的差分约束】
    ZOJ 1232 【灵活运用FLOYD】 【图DP】
    POJ 3013 【需要一点点思维...】【乘法分配率】
    POJ 2502 【思维是朴素的最短路 卡输入和建图】
    POJ 2240 【这题貌似可以直接FLOYD 屌丝用SPFA通过枚举找正权值环 顺便学了下map】
    POJ 1860【求解是否存在权值为正的环 屌丝做的第一道权值需要计算的题 想喊一声SPFA万岁】
    POJ 1797 【一种叫做最大生成树的很有趣的贪心】【也可以用dij的变形思想~】
    js 实现slider封装
  • 原文地址:https://www.cnblogs.com/java20130726/p/3218400.html
Copyright © 2011-2022 走看看