当前位置:首页 > PHP教程 > php应用 > 列表

PHP+AJAX实现投票功能的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-06-19 20:49:16 浏览: 评论:0 

这篇文章主要介绍了PHP+AJAX实现投票功能的方法,以完整实例形式分析了php结合Ajax实现投票功能的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下。

本文实例讲述了PHP+AJAX实现投票功能的方法,分享给大家供大家参考,具体如下:

在这个 AJAX 实例中,我们将演示一个投票程序,网页在不重新加载的情况下,就可以获得结果。

本例包括四个元素:

① HTML 表单

② JavaScript

③ PHP 页面

④ 存放结果的文本文件

一、HTML 表单

这是 HTML 页面,它包含一个简单的 HTML 表单,以及一个与 JavaScript 文件的连接:

  1. <html> 
  2. <head> 
  3. <script src="poll.js"></script>  
  4. </head> 
  5. <body> 
  6. <div id="poll"> 
  7. <h2>Do you like PHP and AJAX so far?</h2> 
  8. <form> 
  9. Yes:  
  10. <input type="radio" name="vote" 
  11. value="0" onclick="getVote(this.value)"> 
  12. <br /> 
  13. No:  
  14. <input type="radio" name="vote" 
  15. value="1" onclick="getVote(this.value)"> 
  16. </form> 
  17. </div> 
  18. </body> 
  19. </html> 

例子解释 - HTML 表单

正如您看到的,上面的 HTML 页面包含一个简单的 HTML 表单,其中的 <div> 元素带有两个单选按钮。

表单这样工作:

1. 当用户选择 "yes" 或 "no" 时,会触发一个事件

2. 当事件触发时,执行 getVote() 函数

3. 围绕该表单的是名为 "poll" 的 <div>。当数据从 getVote() 函数返回时,返回的数据会替代该表单。

二、文本文件

文本文件 (poll_result.txt) 中存储来自投票程序的数据。

它类似这样:

0||0

第一个数字表示 "Yes" 投票,第二个数字表示 "No" 投票。

注释:记得只允许您的 web 服务器来编辑该文本文件。不要让其他人获得访问权,除了 web 服务器 (PHP)。

三、JavaScript

JavaScript 代码存储在 "poll.js" 中,并于 HTML 文档相连接:

  1. var xmlHttp 
  2. function getVote(int) 
  3. xmlHttp=GetXmlHttpObject() 
  4. if (xmlHttp==null) 
  5.  alert ("Browser does not support HTTP Request"
  6.  return 
  7. }  
  8. var url="poll_vote.php" 
  9. url=url+"?vote="+int 
  10. url=url+"&sid="+Math.random() 
  11. xmlHttp.onreadystatechange=stateChanged  
  12. xmlHttp.open("GET",url,true) 
  13. xmlHttp.send(null) 
  14. }  
  15. function stateChanged()  
  16. {  
  17.  if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete"
  18.  {  
  19.  document.getElementById("poll"). 
  20.  innerHTML=xmlHttp.responseText; 
  21.  }  
  22. }  
  23. function GetXmlHttpObject() 
  24. {  
  25. var objXMLHttp=null 
  26. if (window.XMLHttpRequest) 
  27.  objXMLHttp=new XMLHttpRequest() 
  28. else if (window.ActiveXObject) 
  29.  objXMLHttp=new ActiveXObject("Microsoft.XMLHTTP"
  30. return objXMLHttp 

例子解释:

stateChanged() 和 GetXmlHttpObject 函数与 PHP 和 AJAX 请求 这一节中的例子相同。

getVote() 函数

当用户在 HTML 表单中选择 "yes" 或 "no" 时,该函数就会执行。

1. 定义发送到服务器的 url (文件名)

2. 向 url 添加参数 (vote),参数中带有输入字段的内容

3. 添加一个随机数,以防止服务器使用缓存的文件

4. 调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象,并告知该对象当触发一个变化时执行 stateChanged 函数

5. 用给定的 url 来打开 XMLHTTP 对象

6. 向服务器发送 HTTP 请求

四、PHP页面

由 JavaScript 代码调用的服务器页面是名为 "poll_vote.php" 的一个简单的 PHP 文件。

  1. <?php 
  2. $vote = $_REQUEST['vote']; 
  3. //get content of textfile 
  4. $filename = "poll_result.txt"
  5. $content = file($filename); 
  6. //put content in array 
  7. $array = explode("||"$content[0]); 
  8. $yes = $array[0]; 
  9. $no = $array[1]; 
  10. if ($vote == 0) 
  11.  $yes = $yes + 1; 
  12. if ($vote == 1) 
  13.  $no = $no + 1; 
  14. //insert votes to txt file 
  15. $insertvote = $yes."||".$no
  16. $fp = fopen($filename,"w"); 
  17. fputs($fp,$insertvote); 
  18. fclose($fp); 
  19. ?> 
  20. <h2>Result:</h2> 
  21. <table> 
  22. <tr> 
  23. <td>Yes:</td> 
  24. <td> 
  25. <img src="poll.gif" 
  26. width='<?php echo(100*round($yes/($no+$yes),2)); ?>' 
  27. height='20'
  28. <?php echo(100*round($yes/($no+$yes),2)); ?>% 
  29. </td> 
  30. </tr> 
  31. <tr> 
  32. <td>No:</td> 
  33. <td> 
  34. <img src="poll.gif" 
  35. width='<?php echo(100*round($no/($no+$yes),2)); ?>' 
  36. height='20'
  37. <?php echo(100*round($no/($no+$yes),2)); ?>% 
  38. </td> 
  39. </tr> 
  40. </table> 

例子解释:

所选的值从 JavaScript 传来,然后会发生:

1. 获取 "poll_result.txt" 文件的内容

2. 把文件内容放入变量,并向被选变量累加 1

3. 把结果写入 "poll_result.txt" 文件

4. 输出图形化的投票结果

Tags: PHP+AJAX

分享到: