Ответ 1
Вы должны предоставить SimplePager.TextLocation
, который может быть CENTER, LEFT или RIGHT.
<c:SimplePager ui:field='pager' location='CENTER'/>
Что может быть предоставлено атрибуту location
<c:SimplePager ui:field='pager' location='HERE' />
Я пробовал CENTER, но он не работал, я вижу в приложении примера расходов, что у них нет атрибута location, а вместо этого он устанавливается на его создание в UiBinder. Но я не могу это сделать, так как это необходимый атрибут. Что делать?
Вы должны предоставить SimplePager.TextLocation
, который может быть CENTER, LEFT или RIGHT.
<c:SimplePager ui:field='pager' location='CENTER'/>
Единственное решение, которое я вижу на данный момент, работает с @UiField(provided = true)
. Не уверен, что это поможет, но посмотрите на небольшой пример ниже.
ui.xml:
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder" xmlns:g="urn:import:com.google.gwt.user.client.ui"
xmlns:c="urn:import:com.google.gwt.user.cellview.client">
<ui:style>
</ui:style>
<g:HTMLPanel>
<c:CellList ui:field="list" />
<c:SimplePager ui:field="pager" />
<g:Button ui:field="more" text="addMore" />
</g:HTMLPanel>
</ui:UiBinder>
и виджет:
public class TestView extends Composite {
private static TestViewUiBinder uiBinder = GWT.create(TestViewUiBinder.class);
interface TestViewUiBinder extends UiBinder<Widget, TestView> {}
@UiField(provided = true)
CellList<String> list;
@UiField(provided = true)
SimplePager pager;
@UiField
Button more;
private int counter = 0;
private ListDataProvider<String> provider;
public TestView() {
list = new CellList<String>(new TextCell());
pager = new SimplePager();
initWidget(uiBinder.createAndBindUi(this));
provider = new ListDataProvider<String>(getList());
provider.addDataDisplay(list);
pager.setDisplay(list);
pager.setPageSize(5);
}
private LinkedList<String> getList() {
LinkedList<String> list = new LinkedList<String>();
list.add("1st");
list.add("2nd");
list.add("3rd");
list.add("4th");
list.add("5th");
return list;
}
@UiHandler("more")
void onMoreClick(ClickEvent event) {
provider.getList().add(++counter + " more");
}
}
Класс SimplePager не может быть создан UiBinder, потому что у него нет настройки для местоположения, чтобы исправить ошибку.
Альтернатива @UiField (при условии = true), которая позволяет автоматически создавать переменную, создавая метод factory, чтобы проинструктировать страницу за пределами UiBinder о том, как создать экземпляр и при необходимости настроить объект.
Здесь пример метода factory применяется к любому классу @UiField SimplePager. @UiField (при условии = true) будет обрабатывать несколько различных экземпляров, но для одного UiFactory является самым простым, потому что вам не нужно беспокоиться о том, когда используется переменная.
@UiFactory SimplePager createSimplePager() {
return new SimplePager(TextLocation.CENTER);
}