我有一个包含两个表单的页面,每个表单都通过单击选项卡显示,每个表单都有一个“添加”按钮,问题是当我单击添加第一个或第二个表单时,我无法保留数据在数据库中。谢谢你的帮助这里有两个动作来坚持他的两种形式:Controller.php
public function ajouterPSAction()
{
$affairePS = new AffairePanneauSolaire;
$affairePC = new AffairePompeChaleur;
$form1 = $this->createForm(new AffairePanneauSolaireType(), $affairePS);
$form = $this->createForm(new AffairePanneauSolaireType(), $affairePC);
$req = $this->get('request');
if( $req->getMethod() === 'POST' )
{
$form1->bind($req);
if ($form1->isValid()) {
$em = $this->getDoctrine()
->getManager();
$em->persist($affairePS);
$em->flush();
// On définit un message flash
$this->get('session')->getFlashBag()->add('info', 'Affaire bien ajouté');
// Puis on redirige vers la page de visualisation :
return $this->redirect( $this->generateUrl('affaire_voir_affairePS', array(
'id' => $affairePS->getId()
)) ); }
}
// Si on n'est pas en POST, alors on affiche le formulaire
return $this->render('AffaireBundle:Affaires:ajouter.html.twig', array('form' => $form->createView(),'form1' => $form1->createView()));
}
public function ajouterPCAction()
{
$affairePC = new AffairePompeChaleur;
$affairePS = new AffairePanneauSolaire;
$form = $this->createForm(new AffairePompeChaleurType(), $affairePC);
$form1 = $this->createForm(new AffairePanneauSolaireType(), $affairePS);
$req = $this->get('request');
if( $req->getMethod() === 'POST' )
{
$form->bind($req);
if ($form->isValid()) {
$em = $this->getDoctrine()
->getManager();
$em->persist($affairePC);
$em->flush();
// On définit un message flash
$this->get('session')->getFlashBag()->add('info', 'Affaire bien ajouté');
// Puis on redirige vers la page de visualisation :
return $this->redirect( $this->generateUrl('affaire_voir_affairePC', array(
'id' => $affairePC->getId()
)) ); }
}
// Si on n'est pas en POST, alors on affiche le formulaire
return $this->render('AffaireBundle:Affaires:ajouter.html.twig', array('form' => $form->createView(),'form1' => $form1->createView()));
}
对于ajouterPSAction 和ajouterPCaction 这两个动作,我让它们保持原样??或者我必须为每一个动作花费新表格??将拖车表单显示为 2 个选项卡,我让它这样吗?
<div class="tabbable">
<ul id="myTab" class="nav nav-tabs" style="width: 1270px;">
<li><a href="#home" data-toggle="tab">Pompe à chaleur</a></li>
<li><a href="#profile" data-toggle="tab">Panneaux solaires</a></li>
</ul>
<div class="tab-content" style="float: left;">
<div class="tab-pane fade in active" id="home">{% include "AffaireBundle:Affaires:formulairePC.html.twig" %} </div>
<div class="tab-pane fade in " id="profile"> {% include "AffaireBundle:Affaires:formulairePS.html.twig" %}</div>
</div>
</div>