Калитка, Как DropDownChoice выбрать изменить параметры другого DropDownChoice?

Есть ли в Wicket что-то, чтобы сделать два выпадающих выбора, чтобы первый выбор первого допинг-выбора изменил все параметры второго?

2 ответа

Решение

Вы должны использовать значение первого варианта, чтобы определить значение второго.

Я этот пример я решил использовать AjaxFormComponentUpdatingBehavior это запускает обновление Ajax и выполняет изменение значения. Я привожу простой пример заполнения второго DropDownChoice с федеральными штатами страны, которая выбирается в первом.

Обратите внимание, что в этом примере я использую wicket 1.4, хотя в новых версиях он не должен сильно отличаться.

   // two countries
   final String aut = "AUT";
   final String ger = "GER";

   // their states
   final List<String> autStates = Arrays.asList(new String[] { "V", "T", "S", "W" });
   final List<String> gerStates = Arrays.asList(new String[] { "NRW", "B", "BW" });

   // mapping, you should really get this data from a service or have a constant
   final Map<String, List<String>> countryToState = new HashMap<String, List<String>>(2);
   countryToState.put(aut, autStates);
   countryToState.put(ger, gerStates);

   // the container to send back via ajax
   final WebMarkupContainer cont = new WebMarkupContainer("cont");
   cont.setOutputMarkupId(true);
   add(cont);

   final Model<String> stateModel = new Model<String>();
   final DropDownChoice<String> countries = new DropDownChoice<String>("countries", new Model<String>(), new ArrayList<String>(countryToState.keySet()));
   final DropDownChoice<String> states = new DropDownChoice<String>("states", stateModel, new LoadableDetachableModel<List<String>>() {

        @Override
        protected List<String> load() {
            final String country = countries.getModelObject();
            final List<String> list = countryToState.get(country);

            return list != null ? list : new ArrayList<String>(0);
        }
   });

   countries.add(new AjaxFormComponentUpdatingBehavior("onchange") {

    @Override
    protected void onUpdate(AjaxRequestTarget target) {         
                    // just add the container to see the results
        target.addComponent(cont);
    }

   });

   cont.add(countries);
   cont.add(states);

Первый DropDownChoice следует обновить Model второй DropDownChoice на основе и добавить второй DDC к AjaxRequestTarget,

Этот конструктор принимает модель, и вы можете сохранить ссылку на нее, чтобы иметь возможность ее изменить.

Другие вопросы по тегам