PHP+AJAX 投票器功能


Posted in PHP onNovember 11, 2017

终于到AJAX,翻译过来就是”异步Javascript和XML”,他可以实现网页内容的部分加载,可提高用户体验。现在有很多网站都有用这技术,反正你知道他能实现网页的异步更新就差不多了。当然下面的例子都相对简单,并没有体现它这一特点~

投票器

新建文件【 AJAX投票.html】

<html>
<head>
  <script type="text/javascript">
    // 这里是js代码
    function getVote(int) {
      if (window.XMLHttpRequest) {
        // 创建 XMLHttpRequest 对象
        // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行的代码
        xmlhttp = new XMLHttpRequest();
      } else {
        //IE6, IE5 浏览器执行的代码
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
      }
      // 监听响应
      xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState ==4 && xmlhttp.status == 200) {
          // 找到 id 为 poll 的控件
          document.getElementById('poll').innerHTML = xmlhttp.responseText;
        }
      }
      // 向PHP脚本传递主要参数q
      xmlhttp.open("GET", "poll_vote.php?q=" + int, true);
      xmlhttp.send();
    }
  </script>
</head>
<body>
  <div id="poll">
    <h3>你喜欢吃吗?</h3>
    <form>
      是:<input type="radio" name="vote" value="0" onclick="getVote(this.value)"><br>
      否:<input type="radio" name="vote" value="1" onclick="getVote(this.value)">
    </form>
  </div>
</body>
</html>

创建【poll_vote.php】脚本文件

<?php 
  // 接收参数q
  $vote = htmlspecialchars($_REQUEST['q']);
  // 获取文件中存储的数据(这里需要在同一目录下新建一个poll_result.txt文件)
  $filename = "poll_result.txt";
  $conn = file($filename);
  // 将数据分割到数组
  $array = explode("||", $conn[0]);
  $yes = $array[0];
  $no = $array[1];
  $count = $array[2];
  if ($vote == 0) {
    $yes += 1;
    $count += 1;
  }
  if ($vote == 1) {
    $no += 1;
    $count += 1;
  }
  // 将投票数据保存到文档
  $insertvote = $yes . '||' . $no . '||' . $count;
  $fp = fopen($filename, "w");
  fputs($fp, $insertvote);
  fclose($fp);
 ?>
 <h2>结果:</h2>
 <table>
  <tr>
    <td>是:</td>
    <td>
      <span style="display: inline-block; background-color: green; width: <?php echo 100 * round($yes / ($yes + $no), 2);?>px; height: 20px;"></span><?php echo 100 * round($yes / ($yes + $no), 2); ?>%
    </td>
  </tr>
  <tr>
    <td>否:</td>
    <td>
      <span style="display: inline-block; background-color: red; width: <?php echo 100 * round($no / ($yes + $no), 2);?>px; height: 20px;"></span><?php echo 100 * round($no / ($yes + $no), 2); ?>%
    </td>
  </tr>
 </table>
 <p><?php echo "参与人数:" . $count; ?></p>

新建一个空白的文档 【poll_result.txt】

此时目录:

|-AJAX投票.html
|-poll_vote.php
|-poll_result.txt

如果不同则需修改上面相应的代码

效果:

PHP+AJAX 投票器功能
PHP+AJAX 投票器功能

总结

以上所述是小编给大家介绍的PHP+AJAX 投票器功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

PHP 相关文章推荐
PHP编程中八种常见的文件操作方式
Nov 19 PHP
file_get_contents获取不到网页内容的解决方法
Mar 07 PHP
PHP中time(),date(),mktime()区别介绍
Sep 28 PHP
PHP伪静态Rewrite设置之APACHE篇
Jul 30 PHP
php使用GD库创建图片缩略图的方法
Jun 10 PHP
PHP文件上传问题汇总(文件大小检测、大文件上传处理)
Dec 24 PHP
php函数mkdir实现递归创建层级目录
Oct 27 PHP
[原创]php实现 data url的图片生成与保存
Dec 04 PHP
详解EventDispatcher事件分发组件
Dec 25 PHP
php实现的生成迷宫与迷宫寻址算法完整实例
Nov 06 PHP
PHP 记录访客的浏览信息方法
Jan 29 PHP
Thinkphp 框架扩展之驱动扩展实例分析
Apr 27 PHP
PHP实现双链表删除与插入节点的方法示例
Nov 11 #PHP
PHP实现基于栈的后缀表达式求值功能
Nov 10 #PHP
PHP实现基于图的深度优先遍历输出1,2,3...n的全排列功能
Nov 10 #PHP
PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法
Nov 10 #PHP
PHP简单实现循环链表功能示例
Nov 10 #PHP
浅谈使用 Yii2 AssetBundle 中 $publishOptions 的正确姿势
Nov 08 #PHP
php基于环形链表解决约瑟夫环问题示例
Nov 07 #PHP
You might like
PHP正则匹配反斜杠'\'和美元'$'的方法
2017/02/08 PHP
thinkPHP框架实现类似java过滤器的简单方法示例
2018/09/05 PHP
JavaScript 格式字符串的应用
2010/03/29 Javascript
动态的创建一个元素createElement及删除一个元素
2014/01/24 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
2016/01/27 Javascript
Cropper.js 实现裁剪图片并上传(PC端)
2017/08/20 Javascript
jquery实现搜索框功能实例详解
2018/07/23 jQuery
jQuery内容选择器与表单选择器实例分析
2019/06/28 jQuery
javascript设计模式 ? 迭代器模式原理与用法实例分析
2020/04/17 Javascript
Node.js API详解之 timer模块用法实例分析
2020/05/07 Javascript
解决Vue的文本编辑器 vue-quill-editor 小图标样式排布错乱问题
2020/08/03 Javascript
jquery实现拖拽添加元素功能
2020/12/01 jQuery
微信小程序选择图片控件
2021/01/19 Javascript
[05:46]DOTA2英雄梦之声_第18期_陈
2014/06/20 DOTA
[51:34]Ti4主赛事胜者组 DK vs EG 2
2014/07/19 DOTA
Python 序列化 pickle/cPickle模块使用介绍
2014/11/30 Python
Python线程中对join方法的运用的教程
2015/04/09 Python
Python正则表达式实现截取成对括号的方法
2017/01/06 Python
python中使用psutil查看内存占用的情况
2018/06/11 Python
python使用正则表达式来获取文件名的前缀方法
2018/10/21 Python
python中将两组数据放在一起按照某一固定顺序shuffle的实例
2019/07/15 Python
pygame实现烟雨蒙蒙下彩虹雨
2019/11/11 Python
Django实现微信小程序支付的示例代码
2020/09/03 Python
Python jieba结巴分词原理及用法解析
2020/11/05 Python
CSS3实现缺角矩形,折角矩形以及缺角边框
2019/12/20 HTML / CSS
为你的html5网页添加音效示例
2014/04/03 HTML / CSS
Myprotein瑞典官方网站:畅销欧洲英国运动营养品牌
2018/01/22 全球购物
日本快乐生活方式购物网站:Shop Japan
2018/07/17 全球购物
屈臣氏马来西亚官网:Watsons马来西亚
2019/06/15 全球购物
下面代码从性能上考虑,有什么问题
2015/04/03 面试题
如何写出好的Java代码
2014/04/25 面试题
党员自我批评与反省材料
2014/02/10 职场文书
班组长竞聘书
2014/03/31 职场文书
干部个人对照检查材料
2014/08/25 职场文书
护理医院见习报告
2014/11/03 职场文书
教师远程研修感悟
2015/11/18 职场文书