我有一個客戶的聽衆,對於每個客戶我都有一個按鈕來顯示客戶的編輯表單。 我希望當我點擊這個按鈕時,一個函數ajax顯示特定客戶點擊的編輯窗體。Symfony2獲取AJAX表單
我不知道如何才能將表單渲染到使用AJAX執行的動作(控制器)中。
在這裏,我創造我的控制器的形式的方式:
public function editAction($id)
{
if ($this->container->get('request')->isXmlHttpRequest()) {
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('ApplicationClientBundle:Client')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Client entity.');
}
$editForm = $this->createEditForm($entity);
$answer =$this->container->get('templating')->renderResponse('ApplicationClientBundle:Client:index.html.twig', array(
'editForm' => $editForm->createView(),
));
$response = new Response(json_encode(array('editForm'=> $answer)));
$response->headers->set('Content-type', 'application/json; charset=utf-8');
return $response;
}
}
但響應JSON是空的。
我可以在控制器和index.html.twig中做什麼來顯示錶格?
編輯:
在index.html.twig
,我有:
{% block body %}
<div class="content-action">
<div class="col-xs-12 col-sm-6 col-md-6">
<p><span>Raison Sociale :</span><span id="raison_sociale" onclick="functionClick(this)">raison sociale</span></p>
<p><span>Adresse :</span><span id="adresse"> Avenue Majida Boulila imm.....</span><p>
<p><span>M.F. :</span><span id="matriculeFiscale"> 0000000 PES 000</span></p>
<p><span>C.P. :</span><span id="codePostal"> 3027</span></p>
<p><span>Ville :</span><span id=""> Sfax<span/></p>
</div>
<div class="col-xs-12 col-sm-6 col-md-6">
<p><span>Tél. :</span> 74 400 202</p>
<p><span>E-mail :</span><span id="email"> [email protected]</span></p>
<p><span>Nom du contact :</span><span id="nomContact"> nom</span></p>
<p><span>Tél. Mobile :</span><span id="telephone"> 23 447454</span></p>
<p><input type="hidden" id="id" value="2"/> </p>
</div>
<div class="clear"></div>
</div><!--content-action-->
{% endblock %}
{% block javascripts %}
<script>
function functionClick(element){
var id = $("#id").val();
var route = '{{ path('client_edit', { 'id': "PLACEHOLDER" }) }}';
route = route.replace("PLACEHOLDER", id);
$.ajax({
//On lui indique le type d'envoie des informations
type: 'POST',
//On lui indique le chemin de la fonction
url: route,
//On lui donne la valeur du choix qu'on a fait, et id est la variable qui va contenir notre valeur, nous la retrouvons dans notre controller
//Enfin nous lui disons de remplir notre formulaire avec le resultat
success: function(response)
{
element.innerHTML= {{ the_first_fiels_of_the_form }};
}
}
);
}
</script>
{% endblock %}
我想有the_first_fiels_of_the_form
在點擊的元素。
我這樣做:the_first_fiels_of_the_form ={{form_widget(editForm.raisonSociale)}}
但沒有結果。
好吧,讓我們稍微詳細一點:你可以提供模板,你在哪裏做Ajax調用(重要的位,而不是整個事情)和模板'ApplicationClientBundle:Client:index.html.twig' – Koalabaerchen 2014-11-21 10:26:31
我編輯我的文章 – Aminesrine 2014-11-21 10:40:09
渲染模板實際返回什麼?是否設置了$ answer? – RoToRa 2014-11-21 12:01:28