목차
구조를 위한 HTML 및 CSS 작성
jQuery를 작성하여 상호작용 구현
PHP를 작성하여 투표 기록
最终想法
백엔드 개발 PHP 튜토리얼 jQuery, AJAX 및 PHP를 사용하여 별 5개 등급 시스템 구축

jQuery, AJAX 및 PHP를 사용하여 별 5개 등급 시스템 구축

Aug 28, 2023 pm 04:41 PM

使用 jQuery、AJAX 和 PHP 构建 5 星级评级系统

웹사이트의 별점 시스템을 통해 사용자는 쉽게 피드백을 제공하고 다른 사람의 선택을 도울 수 있습니다. 고객이 제품을 어떻게 좋아하는지에 대한 피드백을 기업에 제공합니다. 별점은 웹사이트와 해당 제품에 대한 신뢰를 구축하는 데도 도움이 됩니다.

모든 주요 전자상거래 웹사이트에서는 등급을 사용하여 구매자에게 제품에서 기대할 수 있는 품질을 알립니다.

이 튜토리얼에서는 자신만의 별 5개 등급 시스템을 구축하는 방법을 보여 드리겠습니다.

구조를 위한 HTML 및 CSS 작성

별점 시스템 구축 과정의 첫 번째 단계는 페이지에 표시하려는 요소에 따라 마크업을 작성하는 것입니다.

우리는 평가 위젯에 영화 이름을 꼭 포함하고 싶습니다. 또한 사용자가 클릭하여 투표할 수 있는 위젯 내에 별 5개를 표시해야 합니다. 사용자가 투표한 후에는 투표 데이터도 표시됩니다.

다음 HTML은 이 모든 것을 달성합니다:

으아악

별표를 추가하기 위해 Font Awesome 라이브러리를 사용하고 있습니다. 기본적으로 별에 검정색 선이 있고 채우기가 없기를 원합니다. fa-regular 수업은 우리를 위해 이것을 합니다.

또한 사용자가 별 위로 마우스를 가져가면 별의 색상이 연한 노란색으로 바뀌고 사용자가 별을 클릭하면 등급이 기록되었음을 나타내기 위해 주황색으로 바뀌기를 원합니다. 다음 CSS가 모든 작업을 수행합니다.

으아악

jQuery를 작성하여 상호작용 구현

이제 일부 jQuery를 사용하여 사용자 이벤트에 응답하겠습니다. 우리 별에서 추적하고 싶은 두 가지 이벤트가 있습니다.

우리의 떠다니는 별과 이전의 모든 형제들을 노란색으로 바꾸는 mouseover 이벤트부터 시작하겠습니다. 그러나 이는 사용자가 투표 등록을 위해 별표를 클릭하지 않은 경우에만 발생합니다. Font Awesome 별표 아이콘의 클래스를 조작하여 이 작업을 수행하겠습니다.

우리에게 필요한 코드는 다음과 같습니다:

으아악

우리는 if 语句来检查我们当前悬停的明星是否有任何兄弟姐妹,并且附加了 vote-recorded 클래스를 사용합니다. 그러한 요소가 있으면 투표가 기록되었음을 나타냅니다. 이 경우 우리는 어떤 클래스 조작도 하지 않습니다.

그러나 투표가 아직 기록되지 않은 경우 현재 요소와 그 이전의 모든 형제 항목을 가져오고 여기에 fa-solidyellow 클래스를 추가합니다. 또한 현재 요소 뒤에 오는 모든 형제 요소에서 이러한 클래스를 제거합니다.

이제 올바른 영화에 등급을 추가하기 위한 핸들러click 事件的 jQuery 代码。每当用户点击第四颗星时,我们就知道他们想给电影评分为四颗星。所以我们记录之前兄弟的数量并加一得到 rating。我们还记录 movie_id를 작성하겠습니다.

으아악

해당 영화에 대한 투표가 기록되었는지 다시 확인합니다. 투표가 아직 기록되지 않은 경우 현재 클릭한 요소와 이전의 모든 형제 항목에 vote-recorded 클래스를 추가합니다.

또한 jQuery post() 메서드를 사용하여 POST 요청을 통해 투표 데이터를 백엔드로 보냅니다. 첫 번째 매개변수는 요청을 처리할 PHP 스크립트의 URL이고, 두 번째 매개변수는 처리하려는 데이터입니다.

또한 요청을 성공적으로 처리한 후 서버에서 전송된 데이터를 추가로 처리하기 위해 done()에서 콜백을 제공합니다.

다음 CodePen 데모는 평가 시스템의 프런트 엔드가 어떤 모습인지 보여줍니다.

PHP를 작성하여 투표 기록

백엔드에 투표 기록을 저장하기 위해 MySQL 데이터베이스를 사용할 것입니다. 원하는 애플리케이션을 사용하여 데이터베이스를 관리할 수 있습니다. 저는 phpMyAdmin을 사용하고 있습니다. 여기서 첫 번째 단계는 rating_test。现在,我们将在数据库中创建一个名为 movie_ ratings의 테이블이라는 이름을 붙인 데이터베이스를 만드는 것입니다. 데이터베이스에서 다음 SQL 쿼리를 실행하여 테이블을 만듭니다.

으아악

위 명령문을 실행하면 4개의 서로 다른 열이 있는 movie_ ratings라는 테이블이 생성됩니다.

첫 번째는 자동 증가id,它作为我们添加到表中的每条记录的主键。第二个是 movie_id,它将标识一部电影,最多可以包含 128 个字符。第三个是 average_ rating 来存储迄今为止所有投票的平均值。第四个,total_votes이며 총 투표 수를 추적하는 데 사용됩니다.

이전 섹션에서 post() 메서드의 첫 번째 매개변수를 기억해 보세요. 지금 생성해야 하는 파일인 update_atings.php 문자열이 표시됩니다. 이 파일에는 영화 등급을 업데이트하고 기록하는 PHP 코드가 포함됩니다.

$movie_id = $_POST['movie_id'];
$user_rating = $_POST['user_rating'];

$mysqli = new mysqli('localhost', 'root', '', 'rating_test');

if ($mysqli->connect_errno) {
    die("Error while connecting: " . $mysqli->connect_error);
}
로그인 후 복사

我们首先使用 $_POST 获取 POST 数据,然后创建一个新的 mysqli 对象来建立与数据库的连接。然后我们检查 connect_errno 的值,看看我们的数据库连接调用期间是否出现错误。

$rating_query = $mysqli->query("SELECT * from `movie_ratings` WHERE `movie_id` = '$movie_id'");
$rating_query_rows = mysqli_num_rows($rating_query);

if($rating_query_rows == 0) {
    $mysqli->query("INSERT INTO `movie_ratings` (`movie_id`, `average_rating`, `total_votes`) VALUES ('$movie_id', $user_rating, 1)");

    echo "Average Rating: $user_rating Total Votes: 1";
} else {

    $rating_data = $rating_query->fetch_array(MYSQLI_ASSOC);

    $total_votes = $rating_data['total_votes'];
    $average_rating = $rating_data['average_rating'];

    $rating_sum = $average_rating*$total_votes + $user_rating;

    $total_votes += 1;
    $new_average_rating = round($rating_sum/($total_votes), 2);

    $mysqli->query("UPDATE `movie_ratings` SET `average_rating` = $new_average_rating, `total_votes` = $total_votes  WHERE `movie_id` = '$movie_id'");

    echo "Average Rating: $new_average_rating Total Votes: $total_votes";
}
로그인 후 복사

建立连接后,我们运行第一个查询来查看是否已存在要更新其评分的电影的行。

如果没有这样的电影,我们运行另一个查询以将电影插入表中。由于这是该电影的第一次投票,因此我们将总票数设置为 1。

但是,如果表中已经有一行包含我们传递的 movie_id,我们将从该行获取电影的总票数和当前平均评分。之后,我们计算新的评分并相应更新数据库。

最后,我们回显平均评分和总票数的新值以将其显示给用户。

最终想法

为了简单起见,这不是 100% 完整的解决方案。为了扩展这个项目,我们应该存储一个 cookie 以确保人们只投票一次,甚至记录 IP 地址。然而,这是一个很好的开始,并且非常适合跟踪对您网站上的博客文章、评论和图像等项目的投票。

위 내용은 jQuery, AJAX 및 PHP를 사용하여 별 5개 등급 시스템 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel의 플래시 세션 데이터로 작업합니다 Laravel의 플래시 세션 데이터로 작업합니다 Mar 12, 2025 pm 05:08 PM

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

PHP에서 늦은 정적 결합의 개념을 설명하십시오. PHP에서 늦은 정적 결합의 개념을 설명하십시오. Mar 21, 2025 pm 01:33 PM

기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. 프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. Mar 28, 2025 pm 05:12 PM

이 기사에서는 프레임 워크에 사용자 정의 기능 추가, 아키텍처 이해, 확장 지점 식별 및 통합 및 디버깅을위한 모범 사례에 중점을 둡니다.

프레임 워크 보안 기능 : 취약점 보호. 프레임 워크 보안 기능 : 취약점 보호. Mar 28, 2025 pm 05:11 PM

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

See all articles