L'exemple de cet article décrit comment jQuery ajax implémente la fonction similaire à l'article. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Il y a quelques jours, quelqu'un m'a demandé la fonction J'aime dans le coin supérieur droit de ce site. Mai Cong y a réfléchi et a décidé de partager cette fonction. J'espère que cette fonction apportera du confort à tout le monde.
Le code est très simple, implémenté par jQuery php.
Code jQuery :
jQuery(document).ready(function($) { $(".zan").click(function(e){ var $i=$(".zan i"), $b=$("<b>").text("+1"), n=parseInt($i.text()); $b.css({ "bottom":0, "z-index":999, }); $i.text(n+1); $(".zan").append($b); $b.animate({"bottom":100,"opacity":0},1000,function(){$b.remove();}); var d = setInterval(function(){ clearInterval(d); if($(".zan b").length == 1){ $.post("",{zan:$i.text()}) } },1000) e.stopPropagation(); }); });
code php :
<?php $path = "zan.txt"; if(isset($_POST['zan'])){ $num = (int)$_POST['zan']; $save = fopen($path,"w"); fwrite($save,$num); fclose($save); echo "good"; exit(); $zan = file_exists($path) ? intval(file_get_contents($path)) : 0; } ?>
code html :
<div class="main"> <div class="zan"><em>看官们给了 <i><?php echo $zan; ?></i> 个赞</em></div> </div>
Avec le style CSS approprié :
.main { position: relative; font-size: 10pt; line-height: 18px; margin: 40px auto; width: 800px; height: 170px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; -o-user-select: none; user-select: none;} .zan { position: absolute; top: 20%; left: 45%; width: 160px; height: 110px; background: url("zan.jpg") center no-repeat; cursor: pointer; opacity: 0.85; } .zan:active { opacity: 1; } .zan em { position: absolute; color: #333; font-style: normal; bottom: -15px; width: 100%; text-align: center; } .zan i { font-style: normal; color: #E94F06; } .zan b { position: absolute; color: #E94F06; font-style: normal; bottom: -15px; width: 100%; text-align: center; }
Ça y est, faites simple !
Voici le code complet :
<?php $path = "zan.txt"; if(isset($_POST['zan'])){ $num = (int)$_POST['zan']; $save = fopen($path,"w"); fwrite($save,$num); fclose($save); echo "good"; exit(); } $zan = file_exists($path) ? intval(file_get_contents($path)) : 0; ?> <!doctype html> <html> <head> <meta charset="utf-8"> <title>我要点赞</title> <style> .main { position: relative; font-size: 10pt; line-height: 18px; margin: 40px auto; width: 800px; height: 170px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; -o-user-select: none; user-select: none;} .zan { position: absolute; top: 20%; left: 45%; width: 160px; height: 110px; background: url("zan.jpg") center no-repeat; cursor: pointer; opacity: 0.85; } .zan:active { opacity: 1; } .zan em { position: absolute; color: #333; font-style: normal; bottom: -15px; width: 100%; text-align: center; } .zan i { font-style: normal; color: #E94F06; } .zan b { position: absolute; color: #E94F06; font-style: normal; bottom: -15px; width: 100%; text-align: center; } </style> </head> <body> <div class="main"> <div class="zan"><em>看官们给了 <i><?php echo $zan; ?></i> 个赞</em></div> </div> <script src="jquery.min.js"></script> <script> jQuery(document).ready(function($) { $(".zan").click(function(e){ var $i=$(".zan i"), $b=$("<b>").text("+1"), n=parseInt($i.text()); $b.css({ "bottom":0, "z-index":999, }); $i.text(n+1); $(".zan").append($b); $b.animate({"bottom":100,"opacity":0},1000,function(){$b.remove();}); var d = setInterval(function(){ clearInterval(d); if($(".zan b").length == 1){ $.post("",{zan:$i.text()}) } },1000) e.stopPropagation(); }); }); </script> </body> </html>
Le titre dit qu'il n'y a pas de limite aux likes, alors Mai Cong va vous dire une petite astuce :
/* 怒赞 */ jQuery.noConflict(); function zan() { setInterval(function () { jQuery(".zan").click(); zan(); }, 600) } zan();
Bien sûr, si vous utilisez Accelerate CC (comme Mai Cong) et recevez trop de demandes de like, vous serez bloqué ! Sauf si vous annulez le POST dans jQuery
J'espère que cet article sera utile à tous ceux qui programment jQuery.