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语法(4)
Oct 09 PHP
用PHP来写记数器(详细介绍)
Oct 09 PHP
PHP stream_context_create()作用和用法分析
Mar 29 PHP
一个php生成16位随机数的代码(两种方法)
Sep 16 PHP
PHP 自动加载的简单实现(推荐)
Aug 12 PHP
php5.3后静态绑定用法详解
Nov 11 PHP
PHP面向对象之事务脚本模式(详解)
Jun 07 PHP
PHP框架laravel的.env文件配置教程
Jun 07 PHP
php-fpm添加service服务的例子
Apr 27 PHP
thinkPHP框架整合tcpdf插件操作示例
Aug 07 PHP
PHP判断是否是微信打开还是浏览器打开的方法
Feb 27 PHP
laravel实现查询最后执行的一条sql语句的方法
Oct 09 PHP
PHP实现双链表删除与插入节点的方法示例
Nov 11 #PHP
PHP实现基于栈的后缀表达式求值功能
Nov 10 #PHP
PHP实现基于图的深度优先遍历输出1,2,3...n的全排列功能
Nov 10 #PHP
PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法
Nov 10 #PHP
PHP用函数嵌入网站访问量计数器
Oct 27 #PHP
PHP实现网站访问量计数器
Oct 27 #PHP
在 Laravel 中 “规范” 的开发短信验证码发送功能
Oct 26 #PHP
You might like
php zlib压缩和解压缩swf文件的代码
2008/12/30 PHP
ThinkPHP CURD方法之limit方法详解
2014/06/18 PHP
PHP和javascript常用正则表达式及用法实例
2014/07/01 PHP
zen_cart实现支付前生成订单的方法
2016/05/06 PHP
Yii2数据库操作常用方法小结
2017/05/04 PHP
PHP实现微信红包金额拆分试玩的算法示例
2018/04/07 PHP
PHP 文件上传限制问题
2019/09/01 PHP
网页javascript精华代码集
2007/01/24 Javascript
jQuery实现字符串按指定长度加入特定内容的方法
2015/03/11 Javascript
jQuery实用技巧必备(上)
2015/11/02 Javascript
深入剖析javascript中的exec与match方法
2016/05/18 Javascript
javascript的document中的动态添加标签实现方法
2016/10/24 Javascript
ES6数组的扩展详解
2017/04/25 Javascript
JavaScript使用闭包模仿块级作用域操作示例
2019/01/21 Javascript
图文详解vue框架安装步骤
2019/02/12 Javascript
nodejs语言实现验证码生成功能的示例代码
2019/10/13 NodeJs
vue 封装面包屑组件教程
2020/11/16 Javascript
itchat和matplotlib的结合使用爬取微信信息的实例
2017/08/25 Python
Python探索之实现一个简单的HTTP服务器
2017/10/28 Python
Python 比较文本相似性的方法(difflib,Levenshtein)
2018/10/15 Python
Python之使用adb shell命令启动应用的方法详解
2019/01/07 Python
pyhanlp安装介绍和简单应用
2019/02/22 Python
使用pytorch和torchtext进行文本分类的实例
2020/01/08 Python
Python urlopen()参数代码示例解析
2020/12/10 Python
英国知名的皮手套品牌:Dents
2016/11/13 全球购物
综合实践教学反思
2014/01/31 职场文书
大学军训感言600字
2014/02/25 职场文书
教师党员岗位承诺书
2014/05/29 职场文书
市场调查策划方案
2014/06/10 职场文书
合作协议书模板2014
2014/09/26 职场文书
大学生活委员竞选稿
2015/11/21 职场文书
运动会班级口号霸气押韵
2015/12/24 职场文书
2019年大学生职业生涯规划书最新范文
2019/03/25 职场文书
Oracle 区块链表创建过程详解
2021/05/15 Oracle
vue项目中的支付功能实现(微信支付和支付宝支付)
2022/02/18 Vue.js
JS轻量级函数式编程实现XDM二
2022/06/16 Javascript