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 相关文章推荐
几种显示数据的方法的比较
Oct 09 PHP
其他功能
Oct 09 PHP
浅析php中如何在有限的内存中读取大文件
Jul 02 PHP
php递归使用示例(php递归函数)
Feb 14 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
Sep 27 PHP
php实现的mongodb操作类实例
Apr 03 PHP
浅谈php提交form表单
Jul 01 PHP
Zend Framework动作助手Json用法实例分析
Mar 05 PHP
PHP 极验验证码实例讲解
Sep 29 PHP
php5.5使用PHPMailer-5.2发送邮件的完整步骤
Oct 14 PHP
php+mysql实现的无限分类方法类定义与使用示例
May 27 PHP
php引用传递
Apr 01 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实现异步数据调用的方法
2015/12/24 PHP
Codeigniter里的无刷新上传的实现代码
2019/04/14 PHP
javascript中的几个运算符
2007/06/29 Javascript
JavaScript国旗变换效果代码
2008/08/13 Javascript
jQuery UI Dialog控件中的表单无法正常提交的解决方法
2010/12/19 Javascript
基于jquery跨浏览器显示的file上传控件
2011/10/24 Javascript
JavaScript对象学习经验整理
2013/10/12 Javascript
JavaScript中的object转换成number或string规则介绍
2014/12/31 Javascript
JS简单实现动画弹出层效果
2015/05/05 Javascript
基于jquery实现人物头像跟随鼠标转动
2015/08/23 Javascript
基于jQuery实现网页打印功能
2015/12/01 Javascript
JS上传图片预览插件制作(兼容到IE6)
2016/08/07 Javascript
JS中setTimeout和setInterval的最大延时值详解
2017/02/13 Javascript
Extjs gridpanel 中的checkbox(复选框)根据某行的条件不能选中的解决方法
2017/02/17 Javascript
jquery+css实现侧边导航栏效果
2017/06/12 jQuery
iview给radio按钮组件加点击事件的实例
2017/09/30 Javascript
详解在网页上通过JS实现文本的语音朗读
2019/03/28 Javascript
微信小程序左右滚动公告栏效果代码实例
2019/09/16 Javascript
Vue.js实现立体计算器
2020/02/22 Javascript
解决Vue keep-alive 调用 $destory() 页面不再被缓存的情况
2020/10/30 Javascript
[32:56]完美世界DOTA2联赛PWL S3 Rebirth vs CPG 第二场 12.11
2020/12/16 DOTA
在centos7中分布式部署pyspider
2017/05/03 Python
django 通过ajax完成邮箱用户注册、激活账号的方法
2018/04/17 Python
Python Pexpect库的简单使用方法
2019/01/29 Python
Django处理Ajax发送的Get请求代码详解
2019/07/29 Python
什么是Python变量作用域
2020/06/03 Python
python的dict判断key是否存在的方法
2020/12/09 Python
CSS3实现酷炫的3D旋转透视效果
2019/11/21 HTML / CSS
css3使用animation属性实现炫酷效果(推荐)
2020/02/04 HTML / CSS
一份没有按时交货失信于客户的检讨书
2014/09/19 职场文书
2015年社区党务工作总结
2015/04/21 职场文书
Vue详细的入门笔记
2021/05/10 Vue.js
Pandas||过滤缺失数据||pd.dropna()函数的用法说明
2021/05/14 Python
分享node.js实现简单登录注册的具体代码
2022/04/26 NodeJs
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers
httpclient调用远程接口的方法
2022/08/14 Java/Android