我是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());
现在,我的点击实现仅适用于具有所需ID的第一个元素。但是将来可能会有多个具有相同ID的元素,因此我无法提醒其他元素。
预期结果是当我单击第一个元素时,使用Window.alert()的GWT显示了单击了哪个元素。
答案 0 :(得分:0)
答案很简单。 为了跟踪单击了哪个元素,我使用以下命令修改了大小写:
fileLink.addClickHandler(new ClickHandlerData<Integer>(tabIndex) {
public void onClick(ClickEvent event) {
Window.alert("You clicked on " getData());
}
});
还使用ClickHandlerData实现新类
public abstract class ClickHandlerData<I> implements ClickHandler {
private I data;
public ClickHandlerData(I data) {
this.data = data;
}
public I getData() {
return data;
}
public void setData(I data) {
this.data = data;
}
}