注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 网页制作 > CSS技术应用 内容正文:CSS实现星级评分III

CSS实现星级评分III

发布时间:2006-07-03 19:52:04 来源:友佳学院 网友评论 0 条

首先是实现的原理
从上一个css实现星级评分I 、II,可是看出,只要能识别onclick和将数据记录至数据库中存储,然后从数据库中调用出数据进行计算就
可以得到当前的评分均值——当前的分值。

1.下面是建立数据库的sql

以下是引用片段:
CREATE TABLE ratings(
  id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  total_votes INT NOT NULL,
  total_value INT NOT NULL,
  which_id INT NOT NULL,
  which_table VARCHAR(255),
  used_ips LONGTEXT NULL
  );
2.参数文件引用
以下是引用片段:
<?php
require("connectDB.php");
require("closeDB.php");
require("tableName.php");
require("openDB.php");
?>

3.显示投票程序和更新投票数据程序
以下是引用片段:
<?php
$rating_posted=$_GET['vote'];//pased variable by the the stars value
$id=$_GET['id'];
$query=mysql_query("SELECT total_votes, total_value, used_ips FROM $tableName WHERE id='".$id."' ")or die(" Error: ".mysql_error());
$numbers=mysql_fetch_assoc($query);
$checkIP=unserialize($numbers['used_ips']);
$count=$numbers['total_votes'];//how many votes total
$current_rating=$numbers['total_value'];//total number of rating added together and stored
$sum=$rating_posted+$current_rating;// add together the current vote value and the total vote value
$tense=($count==1) ? "vote" : "votes";//plural form votes/vote
$voted=@mysql_fetch_assoc(@mysql_query("SELECT title FROM $tableName WHERE used_ips LIKE '%".$_SERVER['REMOTE_ADDR']."%' AND id='$id' ")); //Pattern match ip:suggested by Bramus! http://www.bram.us/ - this variable searches through the previous ip address that have voted and returns true or false

if($voted){
echo "<div class=/"rating/">".
"<ul class=/"star-rating/">".
"<li class=/"current-rating/" style=/"width:". @number_format($current_rating/$count,2)*20 ."px;/">Current rating.</li>".
 "<li class=/"one-star/">1</li>".
 "<li class=/"two-stars/" >2</li>".
 "<li class=/"three-stars/">3</li>".
 "<li class=/"four-stars/">4</li>".
 "<li class=/"five-stars/">5</li>".
"</ul>".
  "<p>Rating: <strong>".@number_format($current_rating/$count,2)."</strong> {".$count." ".$tense." cast} <br />You have previously voted.</p></div>";//show the current value of the vote with the current numbers
}else{

if(isset($_GET['vote'])){

if($sum==0){
$added=0;//checking to see if the first vote has been tallied
}else{
$added=$count+1;//increment the current number of votes
}

if(is_array($checkIP)){
array_push($checkIP,$_SERVER['REMOTE_ADDR']);//if it is an array i.e. already has entries the push in another value
}else{
$checkIP=array($_SERVER['REMOTE_ADDR']);//for the first entry
}

$insert=serialize($checkIP);
mysql_query("UPDATE $tableName SET total_votes='".$added."', total_value='".$sum."', used_ips='".$insert."' WHERE id='".$_GET['id']."'");

echo   "<div class=/"rating/"><p>Rating: <strong>".@number_format($sum/$added,2)."</strong> {".$added." ".$tense." cast} <span>Thank you for your vote!</span></p></div>";//show the updated value of the vote
}else{
?>
4.访问者评分程序
以下是引用片段:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <title>CSS: Star Rater Example</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <link href="styles2-1.css" rel="stylesheet" type="text/css" media="all">
  </head>
<body>
<div class="rating">
<p>How clear was this tutorial?</p>
<ul class="star-rating">
<li class="current-rating" style="width:<?php echo @number_format($current_rating/$count,2)*20 ?>px;">Current rating</li>
 <li><a href="<?php echo $_SERVER['PHP_SELF'] . "?" .$_GET['section'] . "&amp;id=" . $_GET['id'] . "&amp;vote=1";?>" title="Rate this 1 star out of 5" class="one-star">1</a></li>
 <li><a href="<?php echo $_SERVER['PHP_SELF'] . "?" .$_GET['section'] . "&amp;id=" . $_GET['id'] . "&amp;vote=1";?>" title="Rate this 2 stars out of 5" class="two-stars" >2</a></li>
 <li><a href="<?php echo $_SERVER['PHP_SELF'] . "?" .$_GET['section'] . "&amp;id=" . $_GET['id'] . "&amp;vote=1";?>" title="Rate this 3 stars out of 5" class="three-stars" >3</a></li>
 <li><a href="<?php echo $_SERVER['PHP_SELF'] . "?" .$_GET['section'] . "&amp;id=" . $_GET['id'] . "&amp;vote=1";?>" title="Rate this 4 stars out of 5" class="four-stars" >4</a></li>
 <li><a href="<?php echo $_SERVER['PHP_SELF'] . "?" .$_GET['section'] . "&amp;id=" . $_GET['id'] . "&amp;vote=1";?>" title="Rate this 5 stars out of 5" class="five-stars" >5</a></li>
</ul>
</body></html>
5.最新评分结果提示
以下是引用片段:
<?php
echo  "<p>Rating: <strong>".@number_format($sum/$count,2)."</strong> {".$count." ".$tense." cast}</p></div>";//show the current updated value of the vote
}  // end isset get vote  
}  //end voted true, false
?>
下一步是将结果记入数据库,现在没有时间去研究了,请大家等待下一篇文章或者去远出处阅读!

原文:Creating a star rating system part (3)
链接:http://slim.climaxdesigns.com/tutorial.php?id=3
版权:版权归原作者所有,翻译文档版权归本人|greengnn,转载请注明出处www.jluvip.com/blog

我们用php来实现
先看看效果:http://gnn.80x86.cn/starrating

相关文章
  • ASP.NET入门随想之检票的老太太
  • 10件傻事将使你的Windows系统不安全
  • [视频]Photoshop照片创意合成:学习思路
  • WPS文档加密、自动保存与备份方法详解
【评论】【收藏本文】【打印】【关闭】
上一篇文章:CSS中的行为——HTC
下一篇文章:CSS中的行为——expression
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
CSS的“顶级技巧”
CSS的“顶级技巧”
如何使用CSS来进行网页排版
如何使用CSS来进行网页排版
CSS样式表教程-If you love css …
CSS样式表教程-If you love css …
推荐阅讯
  • CSS+DIV设计实例:Hover over下的边框变化
  • CSS初级入门:连接属性
  • CSS垂直树形下拉菜单
  • 网页制作基础:如何去掉超链接的下划线
  • 取得input中部分选中(selected)的值
  • 中文排版CSS心得
  • 从基础开始:CSS实用教程(三)
  • 利用CSS的Clip属性来创造多彩文字
  • 总结:用CSS进行网页样式设计攻略全集
  • CSS应用实例:水平线变成虚线
阅读排行
  • 1.如何使用CSS来进行网页排版
  • 2.CSS样式表教程-If you love css …
  • 3.CSS用样式表美化你的网页
  • 4.网页制作:几种所见所得的WEB在线编辑器
  • 5.网页常见可用性错误——表单组件错误
  • 6.CSS+JavaScript打造超酷右键菜单
  • 7.针对浏览器隐藏CSS之九大技巧
  • 8.DIV+CSS网页布局入门
  • 9.搜索引擎的蜘蛛人(ROBOTS)秘密
  • 10.CSS垂直树形下拉菜单
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载