php+jQuery+Ajax实现点赞效果的方法
php+jQuery+Ajax实现点赞效果的方法,
结合实例形式详细介绍了php结合jQuery的ajax无刷新提交实现点赞功能的具体步骤与相关技巧,
需要的朋友可以参考下
php+jQuery+Ajax实现点赞效果具体如下:
数据库设计
先准备两张表,pic表保存的是图片信息,包括图片对应的名称、路径以及图片“赞”总数,pic_ip则记录用户点击赞后的IP数据。
CREATE TABLE IF NOT EXISTS `pic` ( `id` int(11) NOT NULL AUTO_INCREMENT, `pic_name` varchar(60) NOT NULL, `pic_url` varchar(60) NOT NULL, `love` int(11) NOT NULL DEFAULT '0', PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; CREATE TABLE IF NOT EXISTS `pic_ip` ( `id` int(11) NOT NULL AUTO_INCREMENT, `pic_id` int(11) NOT NULL, `ip` varchar(40) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8
index.php
在index.php中,我们通过PHP读取pic表中的图片信息并展示出来,结合CSS,提升页面展示效果。
<?php include_once("connect.php"); $sql = mysql_query("select * from pic"); while($row=mysql_fetch_array($sql)){ $pic_id = $row['id']; $pic_name = $row['pic_name']; $pic_url = $row['pic_url']; $love = $row['love']; ?>
CSS中,我们将定义鼠标滑向和离开红心按钮的动态效果,并定位按钮的位置。
.list{width:760px; margin:20px auto} .list li{float:left; width:360px; height:280px; margin:10px; position:relative} .list li p{position:absolute; top:0; left:0; width:360px; height:24px; line-height:24px; background:#000; opacity:.8;filter:alpha(opacity=80);} .list li p a{padding-left:30px; height:24px; background:url(images/heart.png) no-repeat 4px -1px;color:#fff; font-weight:bold; font-size:14px} .list li p a:hover{background-position:4px -25px;text-decoration:none}
jQuery代码
当用户点击自己喜欢的图片上的红心按钮时,向后台love.php发送ajax请求,请求响应成功后,更新原有的数值
$(function(){ $("p a").click(function(){ var love = $(this); var id = love.attr("rel"); //对应id love.fadeOut(300); //渐隐效果 $.ajax({ type:"POST", url:"love.php", data:"id="+id, cache:false, //不缓存此页面 success:function(data){ love.html(data); love.fadeIn(300); //渐显效果 } }); return false; }); });
love.php
后台love.php接收前端的ajax请求,根据提交的图片id值,查找IP表中是否已有该用户ip的点击记录,如果有则告诉用户已“赞过了”,反之,则进行一下操作:
1、更新图片表中对应的图片love字段值,将数值加1。
2、将该用户IP信息写入到pic_ip表中,用以防止用户重复点击。
3、获取更新后的赞值,即赞该图片的用户总数,并将该总数输出给前端页面。
include_once("connect.php"); //连接数据库 $ip = get_client_ip(); //获取用户IP $id = $_POST['id']; if(!isset($id) || empty($id)) exit; $ip_sql=mysql_query("select ip from pic_ip where pic_id='$id' and ip='$ip'"); $count=mysql_num_rows($ip_sql); if($count==0){ //如果没有记录 $sql = "update pic set love=love+1 where id='$id'"; //更新数据 mysql_query( $sql); $sql_in = "insert into pic_ip (pic_id,ip) values ('$id','$ip')"; //写入数据 mysql_query( $sql_in); $result = mysql_query("select love from pic where id='$id'"); $row = mysql_fetch_array($result); $love = $row['love']; //获取赞数值 echo $love; }else{ echo "赞过了.."; }
我上传的附件中 数据库SQL 你可以直接建立test 数据库UTF8编码的,然后把SQL文件导入进去。修改一下connect.php中数据库的连接信息即可。
总结:
其实就是发了一个ajax请求,比如你要赞一个商品。商品表肯定有一个计数的字段。你发一个请求过去把这个字段+1
该成功了就返回一个现在的数。然后把页面改一下就成了
function Zan( goodsId, a ){ $.post( "/goods/zan/"+goodsId, null,function( ret ){ if( ret.status == 'ok' ) $(a).html( ret.zannum); else alert( ret.data ); },'json' ); }
希望本文所述对大家学习php有所帮助。

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











PHP는 웹사이트 개발에 널리 사용되는 매우 인기 있는 서버측 프로그래밍 언어입니다. 그 중 파일 업로드 및 다운로드는 웹사이트에서 흔히 사용되는 기능 중 하나이며, PHP는 이러한 기능을 구현하기 위한 풍부한 기능과 기술을 제공합니다. 이 기사에서는 웹사이트를 보다 효율적으로 개발할 수 있도록 PHP의 파일 업로드 및 다운로드 기술을 자세히 소개합니다. 파일 업로드 파일 업로드는 로컬 컴퓨터에서 원격 서버로 파일을 전송하는 것을 의미하며, 파일을 업로드한 후 이러한 파일을 저장, 처리 및 표시할 수 있습니다. PHP에서

PHP Kuaishou API 인터페이스 호출 팁: 인터페이스에서 반환된 오류 정보를 처리하는 방법 PHP를 사용하여 Kuaishou API 인터페이스를 호출할 때 인터페이스에서 오류를 반환하는 상황이 자주 발생합니다. 처리 인터페이스에서 반환된 오류 정보에 대해 적절한 처리 및 피드백을 제공하여 애플리케이션의 안정성과 사용자 경험을 개선해야 합니다. 이 기사에서는 인터페이스에서 반환된 오류 정보를 처리하는 몇 가지 기술을 소개하고 해당 코드 예제를 제공합니다. 예외를 포착하려면 try-catch를 사용하십시오. API 인터페이스를 호출할 때 일부 예외 오류가 발생할 수 있습니다.

인터넷의 급속한 발전으로 인해 사용자의 검색 경험을 향상시키기 위해 데이터 페이징 기능을 구현해야 하는 웹사이트가 점점 더 많아지고 있습니다. 웹 개발에서 PHP는 가장 널리 사용되는 서버측 프로그래밍 언어 중 하나이며, 데이터 페이징 기능은 PHP 개발에 없어서는 안 될 기술입니다. 이 기사에서는 프레임워크에서 PHP의 페이징 기술을 적용하는 방법을 소개하고 다양한 페이징 솔루션의 장단점을 비교합니다. 1. 전통적인 PHP 페이징 방법 전통적인 PHP 개발에서 데이터 페이징 기능을 구현하려면 많은 코드를 작성해야 하며 각 페이지에서 이를 반복해야 합니다.

PHP에서 줄 바꿈을 바꾸는 것은 실제 개발, 특히 텍스트 데이터를 처리할 때 자주 발생하는 문제입니다. 개행 문자는 운영 체제에 따라 다르게 표시될 수 있습니다. 일반적으로 Windows 시스템에서는 ""이고 Linux 시스템에서는 ""입니다. 따라서 텍스트 데이터가 정상적인 형식이 되도록 균일하게 줄 바꿈을 처리해야 합니다. 이 기사에서는 PHP에서 개행 문자를 바꾸는 기술을 살펴보고 구체적인 코드 예제를 제공합니다. 1. PHP 내장 함수를 사용하여 줄 바꿈을 처리합니다. PHP는 몇 가지 내장 함수를 제공합니다.

PHP 프로그래밍 팁: 배열에서 누락된 숫자를 빠르게 찾는 방법 프로그래밍을 하다 보면 배열에서 특정 숫자가 누락되었는지 확인해야 하는 상황에 자주 직면하게 됩니다. 이때, 적시에 처리할 수 있도록 배열에서 누락된 숫자를 찾는 빠르고 효과적인 방법이 필요합니다. 이 기사에서는 특정 코드 예제를 사용하여 배열에서 누락된 숫자를 빠르게 찾는 방법을 보여주는 PHP 기반 프로그래밍 기술을 소개합니다. 1. 방법 1: 루프를 사용하여 배열을 순회합니다. 먼저 배열을 반복하여 배열에서 누락된 숫자를 확인할 수 있습니다. 특정 단계

PHP 프로그래밍 팁: 이미지 크기 조정을 처리하는 방법 현대 웹 디자인에서 이미지는 필수적인 부분이며 이미지 크기 조정은 일반적인 작업 중 하나입니다. 이미지 모음을 표시하든, 다양한 크기의 장치 요구 사항에 응답하든, 이미지 크기 조정은 중요한 역할을 합니다. 이 기사에서는 PHP 프로그래밍 언어를 사용하여 이미지 크기 조정을 처리하는 방법을 소개하고 참조용 코드 예제를 첨부합니다. 1. 이미지 크기 조정을 위해 GD 라이브러리를 사용합니다. GD 라이브러리는 PHP의 강력한 이미지 처리 라이브러리로 이미지 크기 조정 기능을 구현할 수 있습니다. 먼저, 다음을 확인하세요.

PHP 고동시성 처리 능력 분석 인터넷의 발달로 인해 웹 사이트 동시 방문에 대한 요구 사항이 점점 더 높아지고 있습니다. 웹사이트 개발을 위한 프로그래밍 언어로서 PHP는 높은 동시 액세스 압력에 직면했을 때 성능과 안정성을 향상시키기 위해 특별한 처리 기술이 필요합니다. 이 기사에서는 PHP의 높은 동시성 처리 기술을 소개하고 코드 예제를 제공합니다. PHP-FPMPHP-FPM(FastCGIProcessManager)을 사용하면 PHP에서 공식적으로 제공하는 프로세스 관리자로,

PHP 개발에서 50가지 기능 구현 기술과 경험 공유를 마스터하세요. 우리는 항상 효율적이고 고품질의 코드 구현을 추구합니다. 개발 효율성과 코드 품질을 향상시키기 위해서는 다양하고 복잡한 개발 요구와 과제에 대처할 수 있는 경험과 기술을 축적해야 합니다. 이 기사에서는 PHP 개발 여정에 있는 모든 사람에게 도움이 되기를 바라며 다양한 기능 구현을 위한 50가지 PHP 개발 팁과 경험을 공유하겠습니다. 적절한 프레임워크 사용: 자신에게 적합한 PHP 프레임워크를 선택하고 익숙해지면 개발 효율성을 높이고
