php+mysql结合Ajax实现点赞功能完整实例
2023-06-13 09:15:43 时间
本文实例讲述了php+mysql结合Ajax实现点赞功能的方法。分享给大家供大家参考。具体如下:
要实现点赞功能,有多种实现方式,这里总结一下利用Ajax,php和mysql来实现点赞的数据的功能。具体步骤如下:
一、页面中的HTML代码部分:
<span>0</span> <buttononclick="goodplus(1);">good+1</button> <span>0</span> <buttononclick="goodplus(2);">good+1</button> <span>0</span> <buttononclick="goodplus(3);">good+1</button> <span>0</span> <buttononclick="goodplus(4);">good+1</button>
二、写javascript
1、实现上面的button的点击事件goodplus
varspan=document.getElementsByTagName("span");//获取存放点赞数的dom varnum;//点赞数 varflag=0;//不同情况的标记 functiongoodplus(gindex){ flag=1; num=parseInt(span.item(gindex-1).innerHTML); if(checkcookie(gindex)==true){ num=num+1; senddata(gindex);//通过Ajax修改页面上的数据 }else{ alert("你已经点过赞咯!") } }
2、页面一打开时就应该更新点赞数据
for(vari=1;i<span.length+1;i++){ senddata(i); }
3、通过Ajax获取数据senddata函数
functionsenddata(aindex){ varxmlhttp; vartxt; if(window.XMLHttpRequest){ xmlhttp=newXMLHttpRequest(); }else{ xmlhttp=newActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState==4&&xmlhttp.status==200){ txt=xmlhttp.responseText;//获取返回的数据 varcookieindex=aindex-1; document.getElementsByTagName("span").item(cookieindex).innerHTML=txt;//赋值 } } xmlhttp.open("GET","路径/index.php?num="+num+"&flag="+flag+"&aindex="+aindex,true); xmlhttp.send(); }
4、通过设置cookie来判断是否已经点赞,如果有cookie则提示已经点赞,如果没有cookie则允许点赞,而且会设置cookie
//判断是否已经存在了cookie functioncheckcookie(gindex){ varthiscookie="goodplus"+gindex; varmapcookie=getCookie(thiscookie) if(mapcookie!=null&&mapcookie!=""){ returnfalse; }else{ setCookie(thiscookie,thiscookie,365); returntrue; } } //获取cookie functiongetCookie(c_name){//获取cookie,参数是名称。 if(document.cookie.length>0){//当cookie不为空的时候就开始查找名称 c_start=document.cookie.indexOf(c_name+"="); if(c_start!=-1){//如果开始的位置不为-1就是找到了、找到了之后就要确定结束的位置 c_start=c_start+c_name.length+1; //cookie的值存在名称和等号的后面,所以内容的开始位置应该是加上长度和1 c_end=document.cookie.indexOf(";",c_start); if(c_end==-1){ c_end=document.cookie.length; } returnunescape(document.cookie.substring(c_start,c_end));//返回内容,解码。 } } return""; } //设置cookie functionsetCookie(c_name,value,expiredays){ //存入名称,值,有效期。有效期到期事件是今天+有效天数。然后存储cookie, varexdate=newDate(); exdate.setDate(exdate.getDate()+expiredays) document.cookie=c_name+"="+escape(value)+((expiredays==null)?"":";expires="+exdate.toGMTString()) }
三、index.php页面:
<?php $num=$_GET["num"]; $aindex=$_GET["aindex"]; $con=mysql_connect("localhost","root",""); if(!$con){ die("Couldnotconnect:".mysql_error()); } mysql_select_db("goodplus",$con); $sql0s="SELECT*FROM`good`where`id`=".$aindex; $sql0=mysql_query($sql0s); if($_GET["flag"]==0){ while($row=mysql_fetch_array($sql0)){ echo$row["value"]; } }elseif($_GET["flag"]==1){ $sql="UPDATE`goodplus`.`good`SET`value`="".$num.""WHERE`good`.`id`=".$aindex; if(!mysql_query($sql,$con)){ die("Error:".mysql_error()); } echo$num; } mysql_close($con) ?>
四、最终的index.html页面如下:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlns="http://www.w3.org/1999/xhtml"> <head> <metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/> <title>无标题文档</title> </head> <body> <span>0</span> <buttononclick="goodplus(1);">good+1</button> <span>0</span> <buttononclick="goodplus(2);">good+1</button> <span>0</span> <buttononclick="goodplus(3);">good+1</button> <span>0</span> <buttononclick="goodplus(4);">good+1</button> <scripttype="text/javascript"> varspan=document.getElementsByTagName("span"); varnum; varflag=0; for(vari=1;i<span.length+1;i++){ senddata(i); } functiongoodplus(gindex){ flag=1; num=parseInt(span.item(gindex-1).innerHTML); if(checkcookie(gindex)==true){ num=num+1; senddata(gindex); }else{ alert("你已经点过赞咯!") } } functionsenddata(aindex){ varxmlhttp; vartxt; if(window.XMLHttpRequest){ xmlhttp=newXMLHttpRequest(); }else{ xmlhttp=newActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState==4&&xmlhttp.status==200){ txt=xmlhttp.responseText; varcookieindex=aindex-1; document.getElementsByTagName("span").item(cookieindex).innerHTML=txt; } } xmlhttp.open("GET","/ajax/json/index.php?num="+num+"&flag="+flag+"&aindex="+aindex,true); xmlhttp.send(); } //判断是否已经存在了cookie functioncheckcookie(gindex){ varthiscookie="sdcity_foodmap_goodplus"+gindex; varmapcookie=getCookie(thiscookie) if(mapcookie!=null&&mapcookie!=""){ returnfalse; }else{ setCookie(thiscookie,thiscookie,365); returntrue; } } //获取cookie functiongetCookie(c_name){ //获取cookie,参数是名称。 if(document.cookie.length>0){ //当cookie不为空的时候就开始查找名称 c_start=document.cookie.indexOf(c_name+"="); if(c_start!=-1){ //如果开始的位置不为-1就是找到了、找到了之后就要确定结束的位置 c_start=c_start+c_name.length+1; //cookie的值存在名称和等号的后面,所以内容的开始位置应该是加上长度和1 c_end=document.cookie.indexOf(";",c_start); if(c_end==-1){ c_end=document.cookie.length; } returnunescape(document.cookie.substring(c_start,c_end));//返回内容,解码。 } } return""; } //设置cookie functionsetCookie(c_name,value,expiredays){ //存入名称,值,有效期。有效期到期事件是今天+有效天数。然后存储cookie, varexdate=newDate(); exdate.setDate(exdate.getDate()+expiredays) document.cookie=c_name+"="+escape(value)+((expiredays==null)?"":";expires="+exdate.toGMTString()) } </script> </body> </html>
希望本文所述对大家的php程序设计有所帮助。
相关文章
- 实现使用Java代码实现MySQL数据库连接(java连接mysql数据库代码)
- MySQL表查询:利用最佳实践获最佳结果(mysql查询表)
- PHP连接MySQL数据库指南(php连接到mysql)
- MySQL操作实例:从入门到精通(mysql操作实例)
- MySQL封装:简化数据库应用程序开发(mysql封装)
- 借助 PHP 与 MySQL 轻松实现文件下载(php和mysql下载)
- 崩溃恢复昨日MySQL数据崩溃灾难(mysql昨天的数据)
- PHP向MySQL中安全插入数据(php插入mysql)
- 解决MySQL数据库列过多问题(mysql列太多)
- PHP如何关闭MySQL数据库连接(php关闭mysql连接)
- MySQL查询:如何查找表名?(mysql查询表名)
- 查看MySQL表编码:一个实例指南(mysql查看表编码)
- MySQL客户端库:驱动程序开发及应用(mysql客户端库)
- MySQL C程序中文乱码解决方案(mysql c 中文乱码)
- 防止MySQL注入攻击,PHP静态解决方案(mysql防注入 php)
- 使用MySQL构建完善的银行系统(银行mysql)
- MySQL实现文本截取:一个实例(mysql 截取字符串)
- PHP与MySQL的更新:让Web应用更稳定!(php mysql 更新)
- MySQL和PHP中的目录结构说明(mysql中php的目录)
- MySQL数据库中的渠道信息管理(cannel mysql)
- Base64加密数据在MySQL中的存储(base64存mysql)
- 密码如何使用CMD记住MySQL账号密码(cmd怎么保存mysql)
- MySQL实现减法运算的方法及应用场景详解(mysql 中减法)
- MySQL多实例的用法和优势(mysql不同实例)
- Mysql 数据库丢失别慌来了解一下 MySQL 不见的可能原因及解决办法(mysql不见)
- 简易步骤用Redis配置MySQL(redis配置mysql)