我想在添加到购物车后添加一个表格行,但问题是在表格行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中的方式不起作用有没有办法做到这一点?
答案 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)
行。请与您的控制器更新您的问题