Maison > Article > Tutoriel CMS > Une astuce pour résoudre le problème de la méthode d'Imperial ECMS consistant à ajouter AJAX au panier sans actualiser
Les principales étapes permettant à Empire ECMS de mettre en œuvre l'ajout sans AJAX au panier sont les suivantes :
1 Modifiez le modèle de contenu du centre commercial et ajoutez le code suivant. en tête :
Le code est le suivant :
<script type="text/javascript" src="[!--news.url--]skin/default/js/jquery.js"></script> <script type="text/javascript" src="[!--news.url--]skin/default/js/addBuyCar.js"></script> <script type="text/javascript"> var newsurl='<?=$public_r[newsurl]?>'; </script>
2. Modifiez le modèle de contenu du centre commercial et ajoutez la partie panier au code suivant :
Le code est comme suit :
<a href="#ecms" onclick="AddProduct([!--classid--],[!--id--]);">加入购物车</a>
Etude recommandée "Tutoriel Empire cms 》
3. Quant au fichier jquery, il est compatible avec les versions 1.3 et 1.4 et peut être téléchargé par toi-même. Le code source du fichier addBuyCar.js est le suivant :
Le code est le suivant :
function AddProduct(classid,id) { $.ajax({ type: "post", url: newsurl+"e/template/ShopSys/addBuyCar.php", data:"classid="+classid+"&id="+id, dataType: "json", success: function (json) { alert(json.msg); } }) }
4. Ajoutez le handler e/template/ShopSys/addBuyCar. .php, son code source est le suivant :
Le code est le suivant :
<?php require("../../class/connect.php"); require("../../class/db_sql.php"); require("../../data/dbcache/class.php"); require("../../class/ShopSysFun.php"); $link=db_connect(); $empire=new mysqlquery();</p> <p>//$_POST $classid=(int)$_POST['classid']; $id=(int)$_POST['id'];</p> <p>//add function function json_AddBuycar($classid,$id){ global $class_r,$empire,$dbtbpre,$public_r; $classid=(int)$classid; $id=(int)$id; if(empty($classid)||empty($id)||empty($class_r[$classid][tbname])) { return json_encode(array('msgid'=>1,'msg'=>'此商品不存在')); } //验证产品是否存在 $num=$empire->gettotal("select count(*) as total from {$dbtbpre}ecms_".$class_r[$classid][tbname]." where classid='$classid' and id='$id' limit 1"); if(!$num) { return json_encode(array('msgid'=>1,'msg'=>'此商品不存在')); } $record="!"; $field="|"; $productid=$classid.",".$id; $buycar=getcvar('mybuycar'); //重复 if(strstr($buycar,"|".$productid."|")) { $pr=explode("|".$productid."|",$buycar); $pr1=explode("!",$pr[1]); $oldbuycar="|".$productid."|".$pr1[0]."!"; //数量 $pr1[0]=ReturnBuycarProductNum($pr1[0]); if(empty($pr1[0])) { $pr1[0]=1; } $newnum=$pr1[0]+1; $newbuycar="|".$productid."|".$newnum."!"; $buycar=str_replace($oldbuycar,$newbuycar,$buycar); } else { //只存放一个 if($public_r['buycarnum']==1) { $buycar=''; } $buycar.="|".$productid."|1!"; } $re=SetBuycar($buycar); if($re) { return json_encode(array('msgid'=>2,'msg'=>'商品加入购物车成功')); } } echo json_AddBuycar($classid,$id); db_close(); $empire=null; ?>
Maintenant, le problème est résolu !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!