2017-01-17 14 views
3

그것은 stackoverflow에 대한 나의 첫 번째 게시물이므로 너무 많은 실수를 저 지르지 않기 바랍니다.Liferay - json responseData로 채워진 항목을 선택하십시오.

Java 목록 작성 및 aui로 보내기와 관련된 문제가 있습니다 : 옵션으로 선택하십시오. 내 목표는 aui를 채우는 것입니다. 옵션 중 하나가 변경 될 때마다을 동적으로 선택하십시오. 예를 들어, 첫 번째 항목 (카운티)을 변경하면 두 번째 및 세 번째 항목 (커뮤니티 및 도시)이 모두 비워지고 선택된 카운티에 따라 데이터로 채워집니다.

쿼리 문자열 매개 변수에 "mvcPath" 매개 변수가있을 때마다이 코드는 기본적으로 전체 페이지의 코드를 복사한다는 결론에 도달했습니다. 이 코드는 "mvcPath"이있을 때마다 잘 작동합니다. 슬프게도 검색 결과에서 선택한 결과 세부 정보로 페이지를 변경하려면이 매개 변수가 필요합니다.

Image showing badly filled select item

Image showing correctly filled select item

자바 코드 :

@Override 
public void serveResource(ResourceRequest resourceRequest, ResourceResponse resourceResponse) 
     throws IOException, PortletException { 
    String communityName = ""; 
    long communityId = 0; 
    String cityName = ""; 
    long cityId = 0; 
    String countySelected = ParamUtil.getString(resourceRequest, "countySelected"); 
    long countySelectedId = ParamUtil.getLong(resourceRequest, "countyDictionaryId"); 
    String communitySelected = ParamUtil.getString(resourceRequest, "communitySelected"); 
    long communitySelectedId = ParamUtil.getLong(resourceRequest, "communityDictionaryId"); 
    JSONArray jsonArray = JSONFactoryUtil.createJSONArray(); 
    if (countySelected.equalsIgnoreCase("countySelected") && countySelectedId != 0) { 
     System.out.println("County id: " + countySelectedId); 
     try { 
      int communitiesCount = CommunityDictionaryLocalServiceUtil.getCommunityDictionariesCount(); 
      List<CommunityDictionary> communities = CommunityDictionaryLocalServiceUtil.getCommunityDictionaries(0, 
        communitiesCount); 
      for (CommunityDictionary community : communities) { 
       if (community.getCountyDictionaryId() == countySelectedId) { 
        communityName = community.getCommunityName(); 
        communityId = community.getCommunityDictionaryId(); 
        JSONObject communityObject = JSONFactoryUtil.createJSONObject(); 
        communityObject.put("communityName", communityName); 
        communityObject.put("communityDictionaryId", communityId); 
        jsonArray.put(communityObject); 
        System.out.print(jsonArray.toString()); 
       } 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } else if (countySelected.equalsIgnoreCase("countySelected") && countySelectedId == 0) { 
     System.out.println("No county chosen."); 
     try { 
      int communitiesCount = CommunityDictionaryLocalServiceUtil.getCommunityDictionariesCount(); 
      List<CommunityDictionary> communities = CommunityDictionaryLocalServiceUtil.getCommunityDictionaries(0, 
        communitiesCount); 
      for (CommunityDictionary community : communities) { 
       communityName = community.getCommunityName(); 
       communityId = community.getCommunityDictionaryId(); 
       JSONObject communityObject = JSONFactoryUtil.createJSONObject(); 
       communityObject.put("communityName", communityName); 
       communityObject.put("communityDictionaryId", communityId); 
       jsonArray.put(communityObject); 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } 
    if (communitySelected.equalsIgnoreCase("communitySelected") && communitySelectedId != 0) { 
     System.out.println("Community id: " + communitySelectedId); 
     try { 
      int citiesCount = CityDictionaryLocalServiceUtil.getCityDictionariesCount(); 
      List<CityDictionary> cities = CityDictionaryLocalServiceUtil.getCityDictionaries(0, citiesCount); 
      for (CityDictionary city : cities) { 
       if (city.getCommunityDictionaryId() == communitySelectedId) { 
        cityName = city.getCityName(); 
        cityId = city.getCityDictionaryId(); 
        JSONObject cityObject = JSONFactoryUtil.createJSONObject(); 
        cityObject.put("cityName", cityName); 
        cityObject.put("cityDictionaryId", cityId); 
        jsonArray.put(cityObject); 
        System.out.print(jsonArray.toString()); 
       } 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } else if (communitySelected.equalsIgnoreCase("communitySelected") && communitySelectedId == 0) { 
     System.out.println("No community chosen."); 
     try { 
      int citiesCount = CityDictionaryLocalServiceUtil.getCityDictionariesCount(); 
      List<CityDictionary> cities = CityDictionaryLocalServiceUtil.getCityDictionaries(0, citiesCount); 
      for (CityDictionary city : cities) { 
       cityName = city.getCityName(); 
       cityId = city.getCityDictionaryId(); 
       JSONObject cityObject = JSONFactoryUtil.createJSONObject(); 
       cityObject.put("cityName", cityName); 
       cityObject.put("cityDictionaryId", cityId); 
       jsonArray.put(cityObject); 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } 
    PrintWriter writer = resourceResponse.getWriter(); 
    writer.write(jsonArray.toString()); 
    writer.flush(); 
    super.serveResource(resourceRequest, resourceResponse); 
} 

스크립트 :

<aui:script> 
AUI().use('aui-base', 'aui-io-request', 'aui-node', 
     function(A) {A.one("#<portlet:namespace />countySelect").on('change', function() { 
      A.io.request('<%= selectionChangedURL %>', 
        { 
       method : 'POST', 
       data : { 
        "<portlet:namespace />countyDictionaryId" : A.one("#<portlet:namespace />countySelect").val(), 
        '<portlet:namespace />countySelected' : 'countySelected' 
        }, 
        dataType : 'json', 
        on : { 
         success : function() { 
          var communitiesList = this.get('responseData'); 
          A.one('#<portlet:namespace />communitySelect').empty(); 
          A.one('#<portlet:namespace />citySelect').empty(); 
          A.one('#<portlet:namespace />communitySelect').prepend("<option value='0'> </option>"); 
          for (var i in communitiesList) { 
           console.info(communitiesList[i]); 
           A.one('#<portlet:namespace />communitySelect').append("<option value='" + communitiesList[i].communityDictionaryId + "'>" + communitiesList[i].communityName + "</option>"); 
           } 
          } 
        } 
        }); 
      }); 
     A.one("#<portlet:namespace />communitySelect").on('change', function() { 
      A.io.request('<%= selectionChangedURL %>', 
        { 
       method : 'POST', 
       data : { 
        "<portlet:namespace />communityDictionaryId" : A.one("#<portlet:namespace />communitySelect").val(), 
        '<portlet:namespace />communitySelected' : 'communitySelected' 
        }, 
        dataType : 'json', 
        on : { 
         success : function() { 
          var citiesList = this.get('responseData'); 
          A.one('#<portlet:namespace />citySelect').empty(); 
          A.one('#<portlet:namespace />citySelect').prepend("<option value='0'> </option>"); 
          for (var i in citiesList) { 
           console.info(citiesList[i]); 
           A.one('#<portlet:namespace />citySelect').append("<option value='" + citiesList[i].cityDictionaryId + "'>" + citiesList[i].cityName + "</option>"); 
           } 
          } 
        } 
        }); 
      }); 
     }); 

+0

, 난 당신이 올바른 정보를 인쇄지고 ... 배열의 한 요소가 보인다과는 카운터로 사용되는 것 같다 :

은 서버 측 코드 브라우저 콘솔? –

+0

응답 해 주셔서 감사합니다! 두 번째 첨부 된 그림에서 올바르게 인쇄 된 정보를 볼 수 있습니다. mvcPath를 사용하지 않는 한 의도 한대로 작동합니다. – Agred

답변

0

을 한 후 서버 측 코드의 일부 변경으로이 문제를 해결할 수있었습니다. 나는 도움이되었던 것만 큼 작은 변화가 어떻게 일어 났는지는 잘 모르겠지만이 스레드를 닫아서 기쁩니다.

코드가 나에게 혼란을 보이는 자바 스크립트 루프
public void serveResource(ResourceRequest resourceRequest, ResourceResponse resourceResponse) 
     throws IOException, PortletException { 
    String communityName = ""; 
    long communityId = 0; 
    String cityName = ""; 
    long cityId = 0; 
    String countySelected = ParamUtil.getString(resourceRequest, "countySelected"); 
    long countySelectedId = ParamUtil.getLong(resourceRequest, "countyDictionaryId"); 
    String communitySelected = ParamUtil.getString(resourceRequest, "communitySelected"); 
    long communitySelectedId = ParamUtil.getLong(resourceRequest, "communityDictionaryId"); 
    JSONArray jsonArray = JSONFactoryUtil.createJSONArray(); 
    if (countySelected.equalsIgnoreCase("countySelected")) { 
     try { 
      int communitiesCount = CommunityDictionaryLocalServiceUtil.getCommunityDictionariesCount(); 
      List<CommunityDictionary> communities = CommunityDictionaryLocalServiceUtil.getCommunityDictionaries(0, 
        communitiesCount); 
      if (countySelectedId == 0) { 
       for (CommunityDictionary community : communities) { 
        communityName = community.getCommunityName(); 
        communityId = community.getCommunityDictionaryId(); 
        JSONObject communityObject = JSONFactoryUtil.createJSONObject(); 
        communityObject.put("communityName", communityName); 
        communityObject.put("communityDictionaryId", communityId); 
        jsonArray.put(communityObject); 
       } 
      } else { 
       for (CommunityDictionary community : communities) { 
        if (community.getCountyDictionaryId() == countySelectedId) { 
         communityName = community.getCommunityName(); 
         communityId = community.getCommunityDictionaryId(); 
         JSONObject communityObject = JSONFactoryUtil.createJSONObject(); 
         communityObject.put("communityName", communityName); 
         communityObject.put("communityDictionaryId", communityId); 
         jsonArray.put(communityObject); 
        } 
       } 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } 
    if (communitySelected.equalsIgnoreCase("communitySelected")) { 
     try { 
      int citiesCount = CityDictionaryLocalServiceUtil.getCityDictionariesCount(); 
      List<CityDictionary> cities = CityDictionaryLocalServiceUtil.getCityDictionaries(0, citiesCount); 
      if (communitySelectedId == 0) { 
       for (CityDictionary city : cities) { 
        cityName = city.getCityName(); 
        cityId = city.getCityDictionaryId(); 
        JSONObject cityObject = JSONFactoryUtil.createJSONObject(); 
        cityObject.put("cityName", cityName); 
        cityObject.put("cityDictionaryId", cityId); 
        jsonArray.put(cityObject); 
       } 
      } else { 
       for (CityDictionary city : cities) { 
        if (city.getCommunityDictionaryId() == communitySelectedId) { 
         cityName = city.getCityName(); 
         cityId = city.getCityDictionaryId(); 
         JSONObject cityObject = JSONFactoryUtil.createJSONObject(); 
         cityObject.put("cityName", cityName); 
         cityObject.put("cityDictionaryId", cityId); 
         jsonArray.put(cityObject); 
        } 
       } 
      } 
     } catch (SystemException e) { 
      e.printStackTrace(); 
     } 
    } 
    PrintWriter writer = new PrintWriter(resourceResponse.getPortletOutputStream()); 
    writer.write(jsonArray.toString()); 
    writer.flush(); 
    super.serveResource(resourceRequest, resourceResponse); 
}