在ajax symfony中的Concat变量

时间:2018-05-23 03:13:37

标签: javascript symfony twig

我想在添加到购物车后添加一个表格行,但问题是在表格行ID中我想做这样的事情

按钮按下后要添加的内容

         function ajouter(idd, prix)
                                {
                                    var test = idd;
                                    var urlEdit = "{{ 
                path('ajouterAuPanier', { 'id': "id" }) }}";
                                    urlEdit=urlEdit.replace("id",test);
                                    $.ajax({
                                        method: 'POST',
                                        url: urlEdit,
                                        success: function(d)
                                        {
                                            if(d.msg == "success")
                                            {
                                                i++;
                                            alert("Item Added");
                                            var prixTotal = parseInt(document.getElementById('prixTotal').innerText);
                                            prixTotal = prixTotal + prix;
                                            document.getElementById('prixTotal').innerText = prixTotal;
                                               var id = {{ panier.id|json_encode() }};
                                                var table = document.getElementById("customers");
                                                var row = table.insertRow();
                                                var cell1 = row.insertCell(0);
                                                var cell2 = row.insertCell(1);
                                                var cell3 = row.insertCell(2);
                                                cell1.innerHTML =document.getElementById(idd+""+idd).innerHTML;
                                                cell2.innerHTML ="<div id="+id+id+id+">1</div><input type=\"submit\" name=\"+\" value=\"+\" style=\"margin-top: -11%;margin-left: 10%;\" onclick=\"updatePlus(i)\">" +
                                                    "<input type=\"submit\" name=\"-\" value=\"-\" style=\"margin-top: -19%;margin-left: 31%;\" onclick=\"updateMinus(i) \">\n";
                                                cell3.innerHTML ="<div id="+id+id+">"+prix+"</div>";
                                           // document.getElementById('cartt').innerHTML +="<div><td> PRODUIT AJOUTE </td><td> 1 </td></div>";
                                           }


                                        }
                                    });
                                }

我的控制器动作:

 public function ajouterauPanierAction($id)
{


        $em = $this->getDoctrine()->getManager();
        $produit = $em->getRepository(Produit::class)->find($id);
        $test = $em->getRepository(Lignedecommande::class)->findExistant($id,$this->getUser()->getId());
        count($test);

        if(($produit != null)&&($test == null))
        {
            $lignedecommande = new Lignedecommande();
            $lignedecommande->setProduitId($produit->getId());
            $lignedecommande->setUserId($this->getUser()->getId()); //à changer avec le fos
            $lignedecommande->setNomProduit($produit->getNom());
            $lignedecommande->setImage($produit->getImage());
            $lignedecommande->setEtat(0);
            $lignedecommande->setQuantite(1);
            $lignedecommande->setPrixTotal($produit->getPrix());
            $em->persist($lignedecommande);
            $em->flush();
            $msg = "success";
        }
        else if($test != null)
        {
            $line = $em->getRepository(Lignedecommande::class)->findExistant($id,$this->getUser()->getId());

            $line[0]->setQuantite($line[0]->getQuantite()+1);
            $line[0]->setPrixTotal($line[0]->getPrixTotal()+$produit->getPrix());
            $em->flush();
            $msg = "done";
        }
        return new JsonResponse(array('msg' => $msg));
}

我需要得到的东西:

                      <div id="panier">
                            <td>{{ panier.nomProduit }} </td>
                    ====> <td><div id={{ panier.id }}{{ panier.id }}{{ panier.id }} > {{ panier.quantite }}</div>

                                <input type="submit" name="+" value="+" style="margin-top: -11%;margin-left: 10%;" onclick="updatePlus({{ panier.id }}) ">
                                <input type="submit" name="-" value="-" style="margin-top: -14%;margin-left: 22%;" onclick="updateMinus({{ panier.id }}) ">


                            </td>
                            <td><div id={{ panier.id }}{{ panier.id }}> {{ panier.prixTotal }} </div><br></td>


                        </div>

我将这个id放在javascript中的方式不起作用有没有办法做到这一点?

2 个答案:

答案 0 :(得分:1)

如果你的javascript代码在脚本标记内,通常它应该可以正常工作

<script type="text/javascript">
    document.getElementById('cartt').innerHTML +="<div id=\"panier\"> 
    <td>"+document.getElementById('nomP'+id).innerHTML+"</td><div id="{{ 
panier.id }}{{ panier.id }}">1</div>";
</script>

但是如果你的代码在外部javascript代码中,我不确定它是否有效,因为twig解释器在加载任何外部js文件之前首先呈现html页面。因此,当加载js文件时,twig解释器已完成作业。 不过我不确定

答案 1 :(得分:1)

行。请与您的控制器更新您的问题