用php制作一个网页来实现简易网上投票系统

发布网友 发布时间:2022-04-21 05:59

我来回答

3个回答

懂视网 时间:2022-04-29 13:40

下面由ThinkPHP教程栏目给给大家介绍ThinkPHP5+jQuery+MySql实现投票功能的方法,希望对需要的朋友也是帮助!

首先效果图如下:

1149706-20200116142405568-1784999916.png

然后分享代码如下:

前端代码:

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>基于THINKPHP5实现红蓝投票功能</title>
<style type="text/css">
 .vote{width:288px; height:300px; margin:40px auto;position:relative}
 .votetitle{width:100%;height:62px; background:url(/static/index/images/icon.png) no-repeat 0 30px; font-size:15px}
 .red{position:absolute; left:0; top:px; height:80px;}
 .blue{position:absolute; right:0; top:px; height:80px;}
 .red p,.blue p{line-height:22px}
 .redhand{position:absolute; left:0;width:36px; height:36px; background:url(/static/index/images/icon.png) no-repeat -1px -38px;cursor:pointer}
 .bluehand{position:absolute; right:0;width:36px; height:36px; background:url(/static/index/images/icon.png) no-repeat -41px -38px;cursor:pointer}
 .grayhand{width:34px; height:34px; background:url(/static/index/images/icon.png) no-repeat -83px -38px;cursor:pointer}
 .redbar{position:absolute; left:42px; margin-top:8px;}
 .bluebar{position:absolute; right:42px; margin-top:8px; }
 .redbar span{display:block; height:6px; background:red; width:100%;border-radius:4px;}
 .bluebar span{display:block; height:6px; background:#09f; width:100%;border-radius:4px; position:absolute; right:0}
 .redbar p{line-height:20px; color:red;}
 .bluebar p{line-height:20px; color:#09f; text-align:right; margin-top:6px}
</style>
<script type="text/javascript" src="/static/index/js/jquery.js"></script>
<script type="text/javascript">
$(function(){
 // 获取初始数据
 getdata('',1);
 
 $(".redhand").click(function(){
 getdata("red",1);
 });
 $(".bluehand").click(function(){
 getdata("blue",1);
 });
});
function getdata(type,vid){
 $.ajax({
 url: "{:url('/index/vote/vote')}",
 data: {type:type,vid:vid},
 type:'POST',
 dataType: 'json',
 success: function (res) {
  console.log(res)
  if (res.status == 0) {
  alert('投票成功')
  var w = 208;
  $("#red_num").html(res.msg.rednum);
  $("#red").css("width",res.msg.red_percent*100+"%");
  var red_bar_w = w*res.msg.red_percent-10;
  $("#red_bar").css("width",red_bar_w);
  $("#blue_num").html(res.msg.bluenum);
  $("#blue").css("width",res.msg.blue_percent*100+"%");
  var blue_bar_w = w*res.msg.blue_percent;
  $("#blue_bar").css("width",blue_bar_w);
  }else{
  alert('投票失败');
  }
 }
 });
}
</script>
</head>
<body>
<div id="main">
 <h2 class="top_title"><a href="http://www.jb51.net/article/71504.htm">ThinkPHP5+jQuery+MySql实现红蓝投票功能</a></h2>
 <div class="vote">
 <div class="votetitle">您对Thinkphp5的看法?</div>
 <div class="red" id="red">
  <p>非常实用</p>
  <div class="redhand"></div>
  <div class="redbar" id="red_bar">
  <span></span>
  <p id="red_num"></p>
  </div>
 </div>
 <div class="blue" id="blue">
  <p style="text-align:right">完全不懂</p>
  <div class="bluehand"></div>
  <div class="bluebar" id="blue_bar">
  <span></span>
  <p id="blue_num"></p>
  </div>
 </div>
 </div>
</div>
</body>
</html>

控制器:

<?php
namespace appindexcontroller;
use thinkController;
/**
 * 投票
 */
class Vote extends Controller
{
 /**
 * 首页
 */
 public function index()
 {
 return $this->fetch();
 }
 /**
 * 投票
 * @param vid type ip
 */
 public function Vote()
 {
 $data = input('post.');
 if (!empty($data)) {
  $data['ip'] = get_ip(); //获取Ip
  // 先检测当前ip是否已经投过票
  $count = model('Vote')->checkIp($data);
  // 检测是否提交了type,提交了即代表点击了按钮,没提交即代表页面初次渲染
  if (!empty($data['type'])) {
  if ($count == '0') { //当前还未投过票 
   // 更新票数 添加用户ip表
   $res = model('Vote')->postVote($data);
   if ($res) {
   
   // 投票成功 获取当前各自的票数
   $info = $this->getPercent($data);
   return return_succ($info);
   }else{
   return return_error('投票失败');
   }
  }else{
   // 已经投过票
   return return_error('您已经投过票了');
  }
  }else{
  // 初次渲染,获取初始数据
  $info = $this->getPercent($data);
  return return_succ($info);
  }
 }else{
  return return_error('数据不能为空');
 }
 }
 // 计算比例
 public function getPercent($data)
 {
 // 投票成功 获取当前各自的票数
 $info = model('Vote')->getInfo($data);
 // 计算比例 保留3位小数
 $info['red_percent'] = round($info['rednum'] / ($info['rednum'] + $info['bluenum']),3);
 $info['blue_percent'] = 1 - $info['red_percent'];
 return $info;
 }
}

模型:

<?php
namespace appindexmodel;
use thinkModel;
use thinkDb;
class Vote extends Model
{
 // 检测当前ip是否已经投过票
 public function checkIp($data)
 {
 $res = Db::table('votes_ip')->where(['vid'=>$data['vid'],'ip'=>$data['ip']])->count();
 return $res;
 }
 // 投票
 public function postVote($data)
 {
 $info = $this->getInfo($data);
 if ($info) {
  Db::startTrans();
  try {
  
  if ($data['type'] == "red") {
   // 更新票数表 
   Db::table('votes')->where(['id'=>$data['vid']])->update(['rednum'=>$info['rednum']+1]);
  }elseif ($data['type'] == "blue") {
   Db::table('votes')->where(['id'=>$data['vid']])->update(['bluenum'=>$info['bluenum']+1]);
  }
  // 添加用户投票ip
  Db::table('votes_ip')->insert(['vid'=>$data['vid'],'ip'=>$data['ip']]);
  Db::commit();
  return true;
  } catch (Exception $e) {
  Db::rollback();
  return false;
  }
 }
 }
 // 获取当前各自的票数
 public function getInfo($data)
 {
 // 获取各自的票数
 $info = Db::table('votes')->where(['id'=>$data['vid']])->find();
 return $info;
 }
}

热心网友 时间:2022-04-29 10:48

<?php
header("Content-type: text/html; charset=utf-8");
$link = mysql_connect( 'localhost', 'root', '') or die('Could not connect to mysql server' );
mysql_select_db('tpxt',$link) or die('Could not select database');
if (isset($_POST['submit'])) {
$sql = "SELECT `id` FROM `table` WHERE `uid` = ".$_POST['uid'];
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$sql = "UPDATE `table` SET `vote`=`vote`+1 WHERE `uid` = ".$_POST['uid'];
mysql_query($sql);
}else{
$sql = "INSERT INTO `table`(uid,vote) VALUES('".$_POST['uid']."','1')";
mysql_query($sql);
}
echo "<script>alert('Ok 投票成功!');</script>";
echo "<script>window.location.reload();</script>";
exit();
}else{
$sql = "SELECT `vote` FROM `table` WHERE `uid` = 3";
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$t3 = mysql_fetch_assoc($result);
}else{
$t3['vote'] = 0; 
}
$sql = "SELECT `vote` FROM `table` WHERE `uid` = 4";
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$t4 = mysql_fetch_assoc($result);
}else{
$t4['vote'] = 0; 
}
$sql = "SELECT `vote` FROM `table` WHERE `uid` = 5";
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$t5 = mysql_fetch_assoc($result);
}else{
$t5['vote'] = 0; 
}
$sql = "SELECT `vote` FROM `table` WHERE `uid` = 6";
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$t6 = mysql_fetch_assoc($result);
}else{
$t6['vote'] = 0; 
}
$sql = "SELECT `vote` FROM `table` WHERE `uid` = 7";
$result = mysql_query($sql);
if ($result && mysql_num_rows($result)) {
$t7 = mysql_fetch_assoc($result);
}else{
$t7['vote'] = 0; 
}
$count = $t3['vote']+$t4['vote']+$t5['vote']+$t6['vote']+$t7['vote'];
$t3_b = $t3['vote']/$count;
$t4_b = $t4['vote']/$count;
$t5_b = $t5['vote']/$count;
$t6_b = $t6['vote']/$count;
$t7_b = $t7['vote']/$count;
}
?>

热心网友 时间:2022-04-29 12:06

用ajax来,判断每个投票的ip地址是否一样!不一样的才能投,*每个ip的投票数!追问我需要具体的程序代码

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com