美好的一天。我这里有一个使用primefaces的拖放实现。这是针对可拖动的。
<p:dataGrid id="availableComputers" value="#{coltsysLab.computer}" var="computer" columns="3" emptyMessage="No Computers Added Yet">
<p:column>
<p:graphicImage id="computer" value="http://localhost:8080/COLTSysResources/resources/images/#{computer.pic}" styleClass="computerImage" rendered="#{computer.status=='AVAILABLE'}"/>
<p:draggable for="computer" revert="true" scope="#{computer.status}" stack=".computerImage"/>
<p:contextMenu for="computer">
<p:menuitem value="Add Information" icon="ui-icon-plusthick" onclick="addInfoDlg.show();" action="#{coltsysLab.passComputerId(computer)}"/>
<p:menuitem process="@this" value="Computer Information" icon="ui-icon-search" oncomplete="viewInfoDlg.show()" action="#{coltsysLab.passComputerId(computer)}"/>
</p:contextMenu>
</p:column>
这适用于可放置的插槽。
<p:dataGrid id="slots" value="#{coltsysLab.op}" var="com1" columns="#{coltsysLab.column}" >
<p:outputPanel id="drop" styleClass="slot">
<p:droppable for="drop" datasource=":organizeForm:availableComputers" tolerance="fit" scope="AVAILABLE">
<p:ajax process="slots" listener="#{coltsysLab.onDrop}" update=":organizeForm:growl :organizeForm:selectedComputers"/>
</p:droppable>
</p:outputPanel>
我能够通过支持bean上的DragDropEvent获取dragId和dropId。但是,我如何能够保存包含可拖动的每个插槽的位置?我想将它保存到数据库中,这样当我打开页面时,它会显示每个可拖动的已保存位置。
-
我添加了kolossus的代码&#39;建议,我想得到拖动对象的位置,但在这里,它输出null
。
String dropId = event.getDropId();
UIComponent theContainer = FacesContext.getCurrentInstance().getViewRoot().findComponent(":organizeForm:slots");
UIComponent theComponent = FacesContext.getCurrentInstance().getViewRoot().findComponent(":organizeForm:availableComputers:computer");
List<UIComponent> childComponents = theContainer.getChildren();
for (UIComponent child : childComponents) {
System.out.println(child.getClientId());
if (dropId.equals(child.getClientId())) {
GraphicImage gImage = (GraphicImage) theComponent;
String currentPosition = gImage.getStyle();
System.out.println(currentPosition);
}
}
当我使用浏览器的inspect元素时,我可以看到它的样式,我将如何获得该值?
答案 0 :(得分:0)
页面元素的位置由style
属性表示。因此,在您的情况下,您只需要获取已删除组件的当前值。为此,您需要通过其clientId检索视图中的组件。不幸的是,JSF没有提供一种简单的方法来获取这些信息(尽管通过id
获取组件非常容易);我只知道蛮力的做法:
String dropId = dde.getDropId(); //get the currently dropped component
UIComponent theContainer = FacesContext.getCurrentInstance().getViewRoot().findComponent("slots"); //you need a reference to the drop container
List<UIComponent> childComponents = theContainer.getChildren(); //all dropped components are children of the datagrid
for(UIComponent child: childComponents){
if(dropId.equals(child.getClientId()));{
GraphicImage gImage = (GraphicImage) theComponent;
String currentPosition = gImage.getStyle();
}
}