我在整页Primefaces布局中有4个布局单元。我在西部布局单位有输出标签。我想拖动它并将其放到中心布局单元。我想将输出标签放到这里的拖放区域是tabView中的一个面板。当我开始拖动输出标签时,不要从西部布局单元出去。此外,当我将它拖出西部布局单元时,它会消失。我怎样才能解决我的问题?我已经工作了2天,但我还没有成功。
这是我的代码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui">
<f:view contentType="text/html">
<h:head>
</h:head>
<h:body>
<p:layout fullPage="true">
<p:layoutUnit id="top" position="north" header="menu" size="100">
</p:layoutUnit>
<p:layoutUnit id="bottom" position="south" header="properties" size="100">
</p:layoutUnit>
<p:layoutUnit id="left" position="west" header="toolbox" size="200" style="overflow: visible" >
<p:outputLabel id="out1" value="outputlable"/>
<p:draggable for="out1" helper="clone"/>
</p:layoutUnit>
<p:layoutUnit id="middle" position="center" header="sayfa 1" >
<p:tabView>
<p:tab id="drop_page_1" title="Page 1">
<p:panel rendered="#{empty myBean.components}">
Please drag any component to here.
</p:panel>
<p:panel id="tab_panel" rendered="#{not empty myBean.components}">
</p:panel>
</p:tab>
<p:droppable id="drop_page_1" for="page_1" >
<p:ajax listener="#{myBean.f_onCompDrop}" />
</p:droppable>
</p:tabView>
</p:layoutUnit>
<p:droppable for="middle" >
<p:ajax listener="#{myBean.f_onCompDrop}" />
</p:droppable>
</p:layout>
</h:body>
</f:view>
</html>
在这里我的豆子:
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import org.primefaces.event.DragDropEvent;
import java.util.List;
import javax.faces.component.UIComponent;
@ManagedBean(name="myBean")
@SessionScoped
public class NewJSFManagedBean {
private List<UIComponent> components;
public NewJSFManagedBean() {
}
public void f_onCompDrop(DragDropEvent ddEvent) {
UIComponent comp = ddEvent.getComponent().findComponent(ddEvent.getDragId());
components.add(comp);
}
public List<UIComponent> getComponents() {
return components;
}
public void setComponents(List<UIComponent> components) {
this.components = components;
}
}
答案 0 :(得分:1)
我有两个布局单位之间拖动项目的问题。我通过css完全解决了它。
我通过更改“溢出”来改变我想要拖出的容器。财产到&#39;可见&#39;。
我做的第二件事是改变&#39; z-index&#39;我想要拖放的容器属性为负值。这为我解决了。
答案 1 :(得分:1)
通过添加appendTo =&#34; @(body)&#34;在draggable组件中修复了在primefaces布局之间拖放的问题。和zindex =&#34; 5&#34; 可拖动组件如下所示:
<p:draggable for="dragIcon" revert="true" helper="clone" appendTo="@(body)" zindex="5"/>