Я новичок в мире GWT, ранее я работал с JavaScript.У меня есть веб-страница, где есть несколько элементов.И мне нужно отследить, какой элемент был нажат с помощью GWT.
Я использую GWT 2.8.1
<div class="FileRow">
<a href="http://l24-n52:/admin/downloadresource=f&table=R_Document&id=405&filename=1000x700.jpg" target="blank" class="fileLink jpg" tabindex="1" id="jpg1"></a>
</div>
<div class="FileRow">
<a href="http://l24- n52:/admin/downloadresource=f&table=R_Document&id=405&filename=1000x700.jpg" target="blank" class="fileLink jpg" tabindex="2" id="jpg2"></a>
</div>
<div class="FileRow">
<a href="http://l24- n52:/admin/downloadresource=f&table=R_Document&id=405&filename=1000x700.jpg" target="blank" class="fileLink pdf" tabindex="3" id="pdf"></a>
</div>
GWT realization
Integer tabIndex = 1, count = 1;
for (final FieldFileInfo info : clientData.getFileInfo()) {
final FlowPanel rowPanel = new FlowPanel();
rowPanel.setStyleName("FileRow");
final HyperlinkPanel fileLink = FileInfoParser.getLinkPanel(info);
fileLink.setStyleName("fileLink");
fileLink.setTabIndex(tabIndex++);
fileLink.setText("");
switch (info.getFileExtension()) {
case "png" :
fileLink.addStyleName("png");
fileLink.getElement().setId("png");
break;
case "jpg" :
fileLink.addStyleName("jpg");
fileLink.getElement().setId("jpg"+count);
break;
case "pdf" :
fileLink.addStyleName("pdf");
fileLink.getElement().setId("pdf");
break;
default :
fileLink.addStyleName("file");
fileLink.getElement().setId("file");
}
rowPanel.add(fileLink);
count++;
}
click realization
Element openPng = Document.get().getElementById("png");
Event.sinkEvents(openPng, Event.ONCLICK);
Event.setEventListener(openPng, new OpenModalHandler());
Теперь реализация моего клика работает только для первого элемента с требуемым идентификатором.Однако в будущем может быть несколько элементов с одинаковым идентификатором, и в результате я не смог предупредить другие элементы.
Ожидаемый результат - когда я нажимаю на первый элемент, GWT с помощью Window.alert () показывает, какой элемент былщелкают.