ajax jqueryはページのあるdivの更新効果を実現します。

4499 ワード

元のコードはこうです。

<div class='control-group'>
   <label class='control-label' for='inputSelect'>    </label>
   <div class='controls'>
    <select id='inputSelect' name="acCpname" onchange="updateAc()">

    <c:forEach items="${list }" var="list">
     <option value="${list.cpname}">${list.cpname }</option>
    </c:forEach>
    </select>
   </div>
   </div>
   <div class='control-group'>
   <label class='control-label'>    </label>
   <div class='controls' id="updateac" style="height: 40px">
    <c:if test="${empty sealtables}">
    <label class='radio inline'>      ,        </label>
    </c:if>
    <c:if test="${not empty sealtables }">
    <c:forEach items="${sealtables}" var="sealtable"
     varStatus="status">
     <label class='radio inline'> <input type='checkbox'
     name="selectSealType" value='${sealtable.sealtype}' />
     ${sealtable.sealtype}
     </label>
    </c:forEach>
    </c:if>
   </div>
   </div>
効果のスクリーンショット:

達成したい効果は、画像の赤いマークの部分をクリックして、プルダウンリストをクリックして、下のチェックボックスの値がプルダウンリストの変化に従って変化します。
まず解決の考えを言います。プルダウンリストにonchangeイベントを追加して、ajaxは非同期でcontrolllerに提出して、データベースの検索を行います。そしてModelAndViewに戻ります。ModelAndViewに設定されたviewは新しいjspページです。このjspページの中に嵌められているコードは変化するdivコードです。
ドロップダウンリストにオンチャンジイベントを追加します。

時間にajax非同期リフレッシュイベントを追加します。
戻ってきた圧力面は直接divにロードされます。

<script>
 function updateAc() {
 $.ajax({
  type : "POST",
  url : '${pageContext.request.contextPath}/updateAc.action',
  data : {
  company : $('#inputSelect').val()
  },
  dataType : "html",
  cache : false,
  async : true,
  contentType : "application/x-www-form-urlencoded;charset=utf-8",
  success : function(data) {
  $("#updateac").html(data);
  },
  error : function() {
  }
 });
 }
</script>
udateAc.actionに提出する:
プルダウンリストで選択した値に基づいて、データベースから該当する値を検索して返します。comp.jspページをレンダリングします。

@RequestMapping(value = "/updateAc.action")
  public ModelAndView updateComp(HttpServletRequest request,Model model){
   ModelAndView modelAndView = new ModelAndView();
   String companyname = request.getParameter("company");
   List<Sealtable> sealtables = service.sealTableBySealCpName(companyname);
   modelAndView.addObject("sealtables", sealtables);
   modelAndView.setViewName("comp");
   return modelAndView;
  }
comp.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
 pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>

<%-- <%@ include file="model.jsp"%> --%>
<div class='controls' id="updateac" style="margin-left: -20px;margin-top: -15px">
 <c:if test="${empty sealtables}">
  <label class='radio inline'>      ,        </label>
 </c:if>
 <c:if test="${not empty sealtables }">
  <c:forEach items="${sealtables}" var="sealtable" varStatus="status">
   <label class='radio inline'> <input type='checkbox'
    name="selectSealType" value='${sealtable.sealtype}' />
    ${sealtable.sealtype}
   </label>
  </c:forEach>
 </c:if>
</div>
現在はページのローカル更新が可能です。
締め括りをつける
ここでajax jqueryについてページのあるdiv更新の効果を実現する文章を紹介します。ajax jqueryページdiv更新の内容は以前の文章を検索してください。または下記の関連記事を引き続きご覧ください。これからもよろしくお願いします。