PHP+Ajax实现文章心情投票功能实例

Stella981
• 阅读 633

一个PHP+Ajax实现文章心情投票功能实例,可以学习了解实现投票的基本流程:通过ajax获取心情图标及柱状图相关数据,当用户点击其中的一个心情图标时,向Ajax.php发送请求,PHP验证用户cookie防止重复提交,然后将mysql中对应的数据心情字段内容加_1,成功后返回前端页面,并更新柱状图和统计数据。_

PHP+Ajax实现文章心情投票功能实例

发表心情:

 1 $id = (int)$_POST['id']; //文章或帖子id  
 2 $mid = (int)$_POST['moodid']; //心情id(配置文件中提供8种心情)  
 3 if(!$mid || !$id){  
 4     echo "此链接不存在";exit;  
 5 }  
 6   
 7 $havemood = chk_mood($id); //验证cookie  
 8 if($havemood==1){  
 9     echo "您已经表达过心情了,保持平常心有益身心健康!";exit;  
10 }  
11 $field = 'mood'.$mid; //数据表中的心情字段,分别用mood0,mood1,mood2...表示不同的心情字段  
12 $query = mysql_query("update mood set ".$field."=".$field."+1 where id=".$id); //对应的心情字段值+1  
13 if($query){  
14     setcookie("mood".$id, $mid.$id, time()+300); //设置cookie,为了测试我们设置cookie过期时间为300s  
15     $query2 = mysql_query("select * from mood where id=$id");  
16     $rs = mysql_fetch_array($query2);//获取该文章的心情数据  
17     $total = $rs['mood0']+$rs['mood1']+$rs['mood2']+$rs['mood3']+$rs['mood4']+$rs['mood5']+  
18 $rs['mood6']+$rs['mood7'];  
19     $height = round(($rs[$field]/$total)*$moodpicheight); //得到总量,并计算当前对应心情的柱状图的高度  
20     echo $height; //返回当前心情柱状的高度  
21 }else{  
22     echo -1; //数据出错  
23 }

获取心情:

 1 $mname = explode(',',$moodname);//心情说明  
 2 $num = count($mname);  
 3 $mpic = explode(',',$moodpic);//心情图标  
 4   
 5 $id = (int)$_GET['id']; //文章或帖子id  
 6 $query = mysql_query("select * from mood where id=$id"); //查询对应的心情数据  
 7 $rs = mysql_fetch_array($query);  
 8 if($rs){  
 9     //得到发表心情的总量  
10     $total = $rs['mood0']+$rs['mood1']+$rs['mood2']+$rs['mood3']+$rs['mood4']+  
11 $rs['mood5']+$rs['mood6']+$rs['mood7'];  
12     for($i=0;$i<$num;$i++){  
13         $field = 'mood'.$i; //字段名  
14         $m_val = intval($rs[$field]); //心情对应的值(次数)  
15         $height = 0; //柱图高度  
16         if($total && $m_val){  
17             $height=round(($m_val/$total)*$moodpicheight); //计算高度  
18         }  
19               
20         $arr[] = array(  
21             'mid' => $i, //对应心情id  
22             'mood_name' => $mname[$i], //心情名称  
23             'mood_pic' => $mpic[$i], //图标  
24             'mood_val' => $m_val, //次数  
25             'height' => $height //柱状图高度  
26         );  
27     }  
28     echo json_encode($arr); //返回JSON数据  
29 }

获取心情列表信息,并展示在页面中:

 1 $(function(){  
 2     $.ajax({  
 3         type: 'GET', //通过get方式发送请求  
 4         url: 'ajax.php', //目标地址  
 5         cache: false, //不缓存数据,注意文明发表心情的数据是实时的,需将cache设置为false,默认是true  
 6         data: 'id=1', //参数,对应文章或帖子的id,本例中固定为1,实际应用中是获取当前文章或帖子的id  
 7         dataType: 'json', //数据类型为json  
 8         error: function(){  
 9             alert('出错了!');  
10         },  
11         success: function(json){ //请求成功后  
12             if(json){  
13                 $.each(json,function(index,array){ //遍历json数据列  
14                     var str = "<li><span>"+array['mood_val']+"</span><div class=\"pillar\"   
15 style=\"height:"+array['height']+"px;\"></div><div class=\"face\"   
16 rel=\""+array['mid']+"\"><img src=\"images/"+array['mood_pic']+"\">  
17 <br/>"+array['mood_name']+"</div></li>";  
18                     $("#mood ul").append(str); //将数据加入到#mood ul列表中  
19                    });   
20             }  
21         }  
22     });  
23     ...  
24 });

数据库表建立直接运行以下代码:

 1 CREATE TABLE IF NOT EXISTS `mood` (  
 2   `id` int(11) NOT NULL,  
 3   `mood0` int(11) NOT NULL DEFAULT '0',  
 4   `mood1` int(11) NOT NULL DEFAULT '0',  
 5   `mood2` int(11) NOT NULL DEFAULT '0',  
 6   `mood3` int(11) NOT NULL DEFAULT '0',  
 7   `mood4` int(11) NOT NULL DEFAULT '0',  
 8   `mood5` int(11) NOT NULL DEFAULT '0',  
 9   `mood6` int(11) NOT NULL DEFAULT '0',  
10   `mood7` int(11) NOT NULL DEFAULT '0',  
11   PRIMARY KEY (`id`)  
12 ) ENGINE=MyISAM DEFAULT CHARSET=utf8;  
13   
14   
15 INSERT INTO `mood` (`id`, `mood0`, `mood1`, `mood2`, `mood3`, `mood4`, `mood5`, `mood6`, `mood7`)  
16 VALUES(1, 8, 6, 20, 16, 6, 9, 15, 21);

本文转自:https://www.sucaihuo.com/php/155.html 转载请注明出处!

点赞
收藏
评论区
推荐文章
凝雪探世界 凝雪探世界
3年前
js-Answers二
前端框架相关什么是单页面应用(SPA)?单页面应用(SPA)是指用户在浏览器加载单一的HTML页面,后续请求都无需再离开此页目标:旨在用为用户提供了更接近本地移动APP或桌面应用程序的体验。流程:第一次请求时,将导航页传输到客户端,其余请求通过RESTAPI获取JSON数据实现:数据的传输通过
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Karen110 Karen110
3年前
Python爬虫 | Selenium爬取当当畅销图书排行
01前言上篇文章我们爬取了,心情相当愉悦,今天这篇文章我们使用Selenium来爬取当当网的畅销图书排行。正所谓书中自有黄金屋,书中自有颜如玉,我们通过读书学习来提高自身的才华,自然能有荣华富贵,也自然少不了漂亮小姐姐。02准备工作在爬取数据前,我们需要安装Selenium库以及Chrome浏览器,并配置好Chro
不是海碗 不是海碗
1年前
为什么需要空气质量API?
空气质量是生活质量的一个重要参数,环境空气的好坏影响着人的健康生活,它可以直接或间接危害到人的心肺功能,空气污染大的地方人容易得各种各样的疾病。同时还会影响我们的心情,在空气质量不好的地方就会感觉很沉闷、压抑甚至是喘不过气来,而在一个空气质量很好的地方,我们就会感觉整个身心豁然开朗,心情都会变得很明媚起来。
梦想橡皮擦 梦想橡皮擦
3年前
10. 比找女朋友还难的技术点,Python 面向对象
有人整个Python学习生涯都没有搞明白的技术之一:面向对象。先放美图调整下心情。十、Python面
Stella981 Stella981
3年前
PHP操作mysql数据库
PHP向MySQL发送数据、PHP操作MySQL数据库是重点中的重点。为大家举一些例子:1.要注册一个用户,是将表单的数据POST发送给PHP写入数据库2.购买一个商品,是将商品信息和用户信息通过PHP写入到数据库3.在线付费,是将用户的充值信息通过PHP写入数据库4.修改头像上传的头像地址得到后,通过PHP修改数据库里头像字段
Stella981 Stella981
3年前
Cookie,Session学习(java servlet编程)
Cookie问题:HTTP协议是没有记忆功能的,一次请求结束后,相关数据会被销毁。如果第二次的请求需要使用相同的请求数据怎么办呢?难道是让用户再次请求书写吗?为了解决这个问题,引入了Cookie技术;Cookie技术其实就是浏览器端实现的数据临时存储技术,保存一些必要的数据,当访问某些网页需要这些数据时,浏览器自动将数据加到HTTP请求
Stella981 Stella981
3年前
PHP+Mysql实现网站顶和踩投票功能实例
PHPMysql实现网站顶和踩投票功能实例,通过记录用户IP,判断用户的投票行为是否有效,该实例也可以扩展到投票系统中。!(https://img.sucaihuo.com/jquery/1/105/big.jpg)首先我们在页面上放置“顶”和“踩”的按钮,即dig\_up和dig\_down,按钮上分别记录了投票的票数以及所占的百分比。
Stella981 Stella981
3年前
JMeter元件图
!(https://oscimg.oschina.net/oscnet/791c91990c80476f864a81e594276889.png)顾翔凡言:不是好的工作会给你带来好的心情,而是好的心情会给你带来好的工作。啄木鸟软件测试培训中心,2017年主打课:各企业可进行裁剪自动化软件
DevOpSec DevOpSec
1年前
kubespray离线安装k8s集群
国内安装k8s集群,下载镜像往往失败或者半天下载不下来,导致安装不成功,影响摸鱼心情。是否可以通过kubespray离线部署k8s集群。完全可以的,准备就绪后,只需10多分钟即可搭建出一套高可用的k8s集群,心情畅悦。