首页 后端开发 PHP问题 PHP如何实现五角星评论(步骤)

PHP如何实现五角星评论(步骤)

Apr 11, 2023 am 10:41 AM

今天,我们将学习如何使用PHP实现五角星评论系统。这种系统通常用于让用户对某个产品、文章或服务进行评分,并显示平均得分。

步骤1:创建HTML表单

我们首先需要创建一个HTML表单,让用户选择要评分的项目,并给它们一个分数:

<form action="submit.php" method="post">
 <p>请对产品进行评分:</p>
 <input type="radio" name="rating" value="1">1分
 <input type="radio" name="rating" value="2">2分
 <input type="radio" name="rating" value="3">3分
 <input type="radio" name="rating" value="4">4分
 <input type="radio" name="rating" value="5">5分
 <br>
 <input type="submit" value="提交">
</form>
登录后复制

步骤2:处理表单数据

在submit.php文件中,我们需要处理用户提交的表单数据并将它们存储到数据库中。首先,我们将检查用户是否选择了一个评分项,如果未选择,则显示错误消息。

接下来,我们将创建一个数据库连接并执行INSERT查询,以将评分数据添加到数据库中。我们还将计算所有评分的平均值,并将其存储在另一个数据库表中。

<?php
 if(empty($_POST[&#39;rating&#39;])) {
   echo "请选择评分项";
 } else {
   $rating = $_POST[&#39;rating&#39;];
   $conn = mysqli_connect("localhost", "username", "password", "database");
   $query = "INSERT INTO ratings (rating) VALUES (&#39;$rating&#39;)";
   mysqli_query($conn, $query);

   $avg_query = "SELECT AVG(rating) as average FROM ratings";
   $result = mysqli_query($conn, $avg_query);
   $row = mysqli_fetch_assoc($result);
   $average = $row[&#39;average&#39;];

   $avg_insert = "INSERT INTO average_rating (average) VALUES ($average)";
   mysqli_query($conn, $avg_insert);

   echo "感谢您的评分!";
 }
?>
登录后复制

步骤3:显示平均得分

最后,我们将向用户显示所有评分的平均值。我们将从数据库中检索此值,并将其显示在网页上。

<?php
 $conn = mysqli_connect("localhost", "username", "password", "database");
 $avg_query = "SELECT AVG(average) as average FROM average_rating";
 $result = mysqli_query($conn, $avg_query);
 $row = mysqli_fetch_assoc($result);
 $average = round($row[&#39;average&#39;], 1);
?>

<p>平均得分: <?php echo $average ?>/5</p>
登录后复制

步骤4:实现五角星评分

现在,我们已经能够收集并显示评分,但是我们想要向用户提供更好的视觉体验。因此,我们将使用五角星代替原始的单选按钮。

为此,我们将使用HTML、CSS和JavaScript来创建五角星,并用PHP来处理用户提交的表单数据。我们将用CSS将五角星设置为灰色,并使用JavaScript在用户将鼠标悬停在星星上时将其着色为黄色。

<style>
 .unchecked {
   color: grey;
 }
 .checked {
   color: yellow;
   cursor: pointer;
 }
</style>

<span id="rating" class="unchecked" onclick="rate(this)">
 <?php
   for($i = 1; $i <= 5; $i++) {
     echo "<i class=&#39;fa fa-star&#39; data-value=&#39;$i&#39;></i>";
   }
 ?>
</span>

<script>
 function rate(element) {
   var stars = element.getElementsByTagName("i");
   for(var i = 0; i < stars.length; i++) {
     stars[i].classList.remove("checked");
     stars[i].classList.add("unchecked");
   }

   var clicked = event.target.dataset.value;
   for(var i = 0; i < clicked; i++) {
     stars[i].classList.remove("unchecked");
     stars[i].classList.add("checked");
   }

   document.querySelector("input[name=&#39;rating&#39;]").value = clicked;
 }
</script>
登录后复制

现在,当用户悬停在星星上时,它们将着色为黄色,并且对应的评分值将放入表单数据中。

最后,我们将PHP提交处理的代码中的单选按钮替换为隐藏的表单输入。该输入将在JavaScript中自动填充。

<span id="rating" class="unchecked" onclick="rate(this)">
 <?php
   for($i = 1; $i <= 5; $i++) {
     echo "<i class=&#39;fa fa-star&#39; data-value=&#39;$i&#39;></i>";
   }
 ?>
</span>

<input type="hidden" name="rating" value="" required>
登录后复制

在这里,我们可以将单选按钮的名称设置为“rating”,并为其设置“required”属性以确保用户选择一个项。

现在,我们已经成功地实现了一个五角星评论系统,可以让用户将评分与网站、产品或文章关联,并向其他用户显示平均得分。这种系统是一种简单而有用的交互功能,可以提高用户体验,并帮助网站所有者更好地了解其受众。

以上是PHP如何实现五角星评论(步骤)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1677
14
CakePHP 教程
1431
52
Laravel 教程
1334
25
PHP教程
1280
29
C# 教程
1257
24