我正在使用primefaces时间表,当对话框窗体弹出时,我需要从SelectOneMenu中选择数据并将它们传递给add函数,以便将它们插入到数据库中。问题是,有时它工作得很好,我可以插入它们,但当我尝试添加另一个插入时,我不能再次工作,你能检查出来吗?我需要知道我是否做错了,因为我找不到问题所在。
Managedbean构造函数:
@PostConstruct
public void init() {
Chauffeurs = new ArrayList<Chauffeur>();
ChauffeurDispo = new dao.gsVoyage().getChauffeursDesponible(Chauffeurs);
model = new DefaultScheduleModel();
vDao=new dao.gsVoyage();
voyage=new Voyage();
try {
listVoyage=vDao.getListVoyages();
}catch(Exception ex) {
ex.printStackTrace();
FacesContext.getCurrentInstance().addMessage(null,new FacesMessage(FacesMessage.SEVERITY_ERROR,"erreur","erreur no sql"));
}
for(Voyage v:listVoyage) {
DefaultScheduleEvent evt=new DefaultScheduleEvent();
evt.setEndDate(v.getDateV());
evt.setStartDate(v.getDateV());
evt.setDescription(v.getChauffeurBean().getMatricule());
evt.setData(v.getIdVoyage());
model.addEvent(evt);
}
}
添加函数:
public void ajouter() {
try {
new dao.gsVoyage().addVoyage(dateV, autocar, chauffeur,chauffeur2,0);
DefaultScheduleEvent evt=new DefaultScheduleEvent();
evt.setEndDate(dateV);
evt.setStartDate(dateV);
evt.setDescription(chauffeur);
model.addEvent(evt);
} catch (Exception e) {
FacesContext.getCurrentInstance().addMessage(null,
new FacesMessage(FacesMessage.SEVERITY_ERROR, "Error!", e.getMessage()));
}
voyage = new Voyage();
}
SelectOneMenu的xhtml:
<label>Chauffeur :</label><br/>
<h:selectOneMenu
value="#{scheduleJava8View.chauffeur}">
<f:selectItems
value="#{scheduleJava8View.chauffeurDispo}"
var="chauffeur" itemValue="#{chauffeur.matricule}"
itemLabel="#{chauffeur.nom}" />
</h:selectOneMenu>
这就是我在xhtml中显示插入数据的方式。
<label>Chauffeur:</label><br/>
<p:inputText value="#{scheduleJava8View.voyage.chauffeurBean.matricule}" />
发布于 2020-06-09 16:25:46
尝试将您的代码更改为以下代码
<h:selectOneMenu
onchange="submit()"
value="#{scheduleJava8View.chauffeur}">
这将调用
setChauffeur(Chauffeur c)
在你的菜豆上。请注意,在本例中,您将需要定义一个converter,因为它不是Java basic类型(int、String,...)。
https://stackoverflow.com/questions/62272647
复制相似问题