php赞
⑴ php想写一个匿名点赞,怎么写
这个问题应该属于javascript类,你这样提问会导致知道分类分到php里去了。
实际上应该是前端控制的,有人说了,可以用jquery的$.post,如果你要用两个form, 那就不能用$('form')这种方式提交,因为会选到两个Form,可以分别加标示区分
<form id='good'>
</form>
<form id='bad'>
</form>
<script>
$('#good').submit();
</script>
而且点赞和踩,这种功能,不需要用到form, 两个Button就可以了
如果实在不清楚可以去后盾人平台搜索视频教学的,都是高质量而且很详细。
⑵ 网站上的赞功能怎么用PHP来做
比如文章的“赞”。
1.不需要记录谁赞了,只统计被赞次数
文章表里加一个被赞次数的字段,用户每点一次“赞”,更新对应文章的被赞次数,也就是这个字段值+1;
2.需要记录用户“赞”的记录
新加一个“赞”的记录表,包括点赞的用户id,被赞的文章id,赞的时间等,用户每点一次赞,就在这个表里新增一条数据。这个可以严格控制用户赞同一篇文章的次数
⑶ 怎么用PHP来做网站上的赞功能
网站上的赞功能类似于统计功能。
总体来说,在页面上做好“赞”连接或者按钮,点击触发事件;事件中可以ajax操作服务器代码,在数据库中执行+1操作等,并返回结果给“赞”数值。
根据是否需要记录用户,分两种情况:
不需要记录谁赞了,只统计被赞次数
文章表里加一个被赞次数的字段,用户每点一次“赞”,更新对应文章的被赞次数,也就是这个字段值+1;
需要记录用户“赞”的记录
新加一个“赞”的记录表,包括点赞的用户id,被赞的文章id,赞的时间等,用户每点一次赞,就在这个表里新增一条数据。这个可以严格控制用户赞同一篇文章的次数
⑷ php怎么做到不能连续点赞
不是需要cookie 是需要将赞的数据保存到数据库中
这样你就不论在任何时候,都可以获取到当前用户是否赞过了,还能控制赞几次!
数据库中保留赞的时间、谁赞的、 这样你就可以限制用户是每天、每小时、还是永久的只能赞一次
⑸ php用数据库怎么实现赞功能
就应该数据库进行数据存储,安全!赞功能很简单,既然是要对文章做功能,那么互动角色就是会员,考虑一个问题,会员需要不需要登录才能点赞,如果不需要登录也可以点赞,你需要有个匿名会员。
那么表方面三个:一个文章表,一个赞表,一个会员表
数据存储:
会员点击了赞,相应的数据存到赞的表里面,这个三个表怎么关联的呢?其核心是赞表,这个表里面存有文章的id号和会员的id号,形成关系。
数据读取:
文章内容读取时候,根据文章的id,从赞的表调取相关数据统计,ok。
⑹ 求PHP文章点赞实现原理 下面有具体说明
不管文章有多少,每篇文章(每条记录)都会有个ID,查看了下你给的“抽屉新热榜”,其点赞的相关源代码如:
<ahref="javascript:;"class="digg-a"title="推荐"><spanclass="hand-iconicon-digg"></span><b>22</b><istyle="display:none">6768728</i></a>
其中的
<istyle="display:none">6768728</i></a>
6768728就是隐藏的ID。
⑺ Php点赞效果的制作代码+解析
数据库设计
先准备两张表,pic表保存的是图片信息,包括图片对应的名称、路径以及图片“赞”总数,pic_ip则记录用户点击赞后的IP数据。
sql">CREATETABLEIFNOTEXISTS`pic`(
`id`int(11)NOTNULLAUTO_INCREMENT,
`pic_name`varchar(60)NOTNULL,
`pic_url`varchar(60)NOTNULL,
`love`int(11)NOTNULLDEFAULT'0',
PRIMARYKEY(`id`)
)ENGINE=MyISAMDEFAULTCHARSET=utf8;
CREATETABLEIFNOTEXISTS`pic_ip`(
`id`int(11)NOTNULLAUTO_INCREMENT,
`pic_id`int(11)NOTNULL,
`ip`varchar(40)NOTNULL,
PRIMARYKEY(`id`)
)ENGINE=MyISAMDEFAULTCHARSET=utf8
index.php
在index.php中,我们通过PHP读取pic表中的图片信息并展示出来,结合CSS,提升页面展示效果。
<?php
include_once("connect.php");
$sql=mysql_query("select*frompic");
while($row=mysql_fetch_array($sql)){
$pic_id=$row['id'];
$pic_name=$row['pic_name'];
$pic_url=$row['pic_url'];
$love=$row['love'];
?>
<li><imgsrc="images/<?phpecho$pic_url;?>"alt="<?phpecho$pic_name;?>"><p><ahref="#"
title="赞"class="img_on"rel="<?phpecho$pic_id;?>"><?phpecho$love;?></a></p></li>
<?php}?>
CSS中,我们将定义鼠标滑向和离开红心按钮的动态效果,并定位按钮的位置。
.list{width:760px;margin:20pxauto}
.listli{float:left;width:360px;height:280px;margin:10px;position:relative}
.listlip{position:absolute;top:0;left:0;width:360px;height:24px;line-height:24px;
background:#000;opacity:.8;filter:alpha(opacity=80);}
.listlipa{padding-left:30px;height:24px;background:url(images/heart.png)no-repeat
4px-1px;color:#fff;font-weight:bold;font-size:14px}
.listlipa:hover{background-position:4px-25px;text-decoration:none}
jQuery代码
当用户点击自己喜欢的图片上的红心按钮时,向后台love.php发送ajax请求,请求响应成功后,更新原有的数值
$(function(){
$("pa").click(function(){
varlove=$(this);
varid=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);//渐显效果
}
});
returnfalse;
});
});
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("selectipfrompic_ipwherepic_id='$id'andip='$ip'");
$count=mysql_num_rows($ip_sql);
if($count==0){//如果没有记录
$sql="updatepicsetlove=love+1whereid='$id'";//更新数据
mysql_query($sql);
$sql_in="insertintopic_ip(pic_id,ip)values('$id','$ip')";//写入数据
mysql_query($sql_in);
$result=mysql_query("selectlovefrompicwhereid='$id'");
$row=mysql_fetch_array($result);
$love=$row['love'];//获取赞数值
echo$love;
}else{
echo"赞过了..";
}
我上传的附件中 数据库SQL 你可以直接建立test 数据库UTF8编码的,然后把SQL文件导入进去。修改一下connect.php中数据库的连接信息即可。
⑻ PHP点赞怎么让其累计一定量后再更新到数据库
要么借助第三方差价减少数据库负载,要么只能实时更新,毕竟静态页面做不到实时从新加载之后保存数据的
⑼ 【新手求助】PHP点赞功能,急!!!
html:
<head>
<scriptsrc="common/js/jquery.js"type="text/javascript"></script>
<scriptlanguage="JavaScript"type="text/javascript">
jQuery(function($){
//这两个是鼠标放上去的效果
$(".zhan").hover(function(){
$(this).children("b").toggle();
});
$(".cai").hover(function(){
$(this).children("b").toggle();
});
});
</script>
<scripttype="text/javascript">
<!--这两个点击事件可以改进的,因为事件问题,所以就弄了两个点击事件
$(document).ready(function(e){
//点赞(给力)
$('.zhan').click(function(){
varzhan=$(this);
varleft=parseInt($(this).offset().left)+10,top=parseInt($(this).offset().top)-10,obj=$(this);
$(this).append('<divid="zhan"><b>+1</b></div>');
$('#zhan').css({'position':'absolute','z-index':'1','color':'#C30','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){
$(this).fadeIn('fast').remove();
varNum=parseInt(obj.find('span').text());
Num++;
obj.find('span').text(Num);
});
$.ajax({
url:"ajax.php?action=zan",
type:"post",
data:"answer_id="+$(this).attr("alt"),
success:function(datas){
zhan.unbind('click');
zhan.parent().parent().siblings().children().children().unbind('click');
zhan.parent().parent().siblings().children().children().attr("class","evaluate-inner");
zhan.attr("class","evaluate-inner");
}
});
});
//踩(不给力)
$('.cai').click(function(){
varcai=$(this);
varleft=parseInt($(this).offset().left)+10,top=parseInt($(this).offset().top)-10,obj=$(this);
$(this).append('<divid="cai"><b>-1</b></div>');
$('#cai').css({'position':'absolute','z-index':'1','color':'#7DAAD5','left':left+'px','top':top+'px'}).animate({top:top-10,left:left+10},'slow',function(){
$(this).fadeIn('fast').remove();
varNum=parseInt(obj.find('span').text());
Num--;
obj.find('span').text(Num);
});
$.ajax({
url:"ajax.php?action=cai",
type:"post",
data:"answer_id="+$(this).attr("alt"),
success:function(datas){
cai.unbind('click');
cai.parent().parent().siblings().children().children().unbind('click');
cai.parent().parent().siblings().children().children().attr("class","evaluate-inner");
cai.attr("class","evaluate-inner");
}
});
});
});
//-->
</script>
</head>
<body>
<!--给力开始-->
<spandata-evaluate="0"id="evaluate-1908165795"class="evaluate"alog-action="qb-zan-btn"><spanclass="evaluate-outer">
<!-----判断对应的回答的id是否在自己创建的存储赞和踩数据的php文件,如果赞或者踩存在一个的话就不能再单击---->
<spanclass="evaluate-inner{if$answer_datas.ans_id|in_array:$zan_listor$answer_datas.ans_id|in_array:$cai_list/}{else/}zhan{/if/}"alt="{$answer_datas.ans_id/}"><bstyle="display:none"class="evaluate-tipevaluate-num-fixed">给力</b><bclass="evaluate-numevaluate-num-fixed"><span>{$answer_datas.goods/}</span></b></span></span></span>
<!--不给力开始-->
<spandata-evaluate="0"id="evaluate-bad-1908165795"class="evaluateevaluate-bad"alog-action="qb-evaluate-outer"><spanclass="evaluate-outer"><spanclass="evaluate-inner{if$answer_datas.ans_id|in_array:$zan_listor$answer_datas.ans_id|in_array:$cai_list/}{else/}cai{/if/}"alt="{$answer_datas.ans_id/}"><bstyle="display:none;"class="evaluate-tipevaluate-num-fixed">不给力</b><bclass="evaluate-numevaluate-num-fixed"style="display:inline-block;"><span>{$answer_datas.bads/}</span></b></span></span></span>
</div>
</div>
<!--评论回答开始-->
</body>
</html>
php
<?php
$action=$_GET['action'];//获取get方式传过来的action
require_once("array/ovovsys_zan.php");
switch($action){
case'detail':
/*****赞开始****/
$zan_list=json_decode(str_replace("'",'"',$zan_json),true);
$zan_lists=array();
foreach($zan_listas$key=>$value){
if($value['uid']==$uid){
$zan_lists[]=$value['answer_id'];
}
}
$smarty->assign('zan_list',$zan_lists);//查询当前登录的会员的uid对应的点赞的回答
/*****赞结束****/
/*****踩开始****/
$cai_list=json_decode(str_replace("'",'"',$cai_json),true);
$cai_lists=array();
foreach($cai_listas$key=>$value){
if($value['uid']==$uid){
$cai_lists[]=$value['answer_id'];
}
}
$smarty->assign('cai_list',$cai_lists);//查询当前登录的会员的uid对应的踩的回答
/*****踩结束****/
$smarty->display('自己的静态页面');
exit();
break;
}
?>
ajax
<?php
require_once("array/ovovsys_zan.php");//这里引用array文件夹中的数组文件
$action=trim($_GET['action']);
if(empty($action)){
echo'<fontcolor=red>参数错误!</font>';exit();
}
switch($action){
case'zan'://点赞(给力)
//$zan_json是数组文件中设置的数组变量,存的是json数据----1
$zan_array=json_decode(str_replace("'",'"',$zan_json),true);
//获取当前的会员的uid-----2
$user_answer['uid']=$uid;
//获取对应的赞的回答的id----2
$user_answer['answer_id']=$_POST['answer_id'];
//将会员的uid和答案的id一块的数组放到指定的数组中----3
$zan_array[]=$user_answer;
$config_path='shuzu/ovovsys_zan.php';
if(!file_exists($config_path)){
$Base->ErrorMsg('文件错误:shuzu/ovovsys_zan.php不存在!');exit();
}
//将指定的数组转换成json数据,并且将双引号转换成单引号,不然放到数组文件中后会出错----4
$zan_new_json=str_replace('"',"'",json_encode($zan_array));
$fp=@fopen($config_path,'r+');
if(!$content=@fread($fp,filesize($config_path))){
$Base->ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit();
}
//执行替换,将数组文件中对应的json数据----5
$content=str_replace("$zan_json="{$zan_json}"","$zan_json="{$zan_new_json}"",$content);
$fp=@fopen($config_path,'w+');
@fwrite($fp,$content);
//修改对应的数据表中的数据----5
$Db->ThisQuery("update`".$db_prefix."ask_answers`set`goods`=`goods`+1where`ans_id`=".$user_answer['answer_id']."");
exit();
break;
case'cai'://踩(不给力)
$cai_array=json_decode(str_replace("'",'"',$cai_json),true);
$user_answer['uid']=$uid;
$user_answer['answer_id']=$_POST['answer_id'];
$cai_array[]=$user_answer;
$config_path='shuzu/ovovsys_zan.php';
if(!file_exists($config_path)){
$Base->ErrorMsg('文件错误:shuzu/ovovsys_zan.php不存在!');exit();
}
$cai_new_json=str_replace('"',"'",json_encode($cai_array));
$fp=@fopen($config_path,'r+');
if(!$content=@fread($fp,filesize($config_path))){
$Base->ErrorMsg('无法读取shuzu/ovovsys_zan.php文件!');exit();
}
$content=str_replace("$cai_json="{$cai_json}"","$cai_json="{$cai_new_json}"",$content);
$fp=@fopen($config_path,'w+');
@fwrite($fp,$content);
$Db->ThisQuery("update`".$db_prefix."ask_answers`set`bads`=`bads`-1where`ans_id`=".$user_answer['answer_id']."");
exit();
break;
}
?>
对应的数据文件(因为创建数据库时没有创建踩和赞的再断,所以这里就用php文件存变量的方式保存了一下答案对应的赞和踩的数据,其中包含用户的id和答案的id):
<?php
$zan_json="";
$cai_json="";
?>
你没看错,就是两个变量
⑽ PHP点赞和踩功能的怎么实现,代码怎么写
这个问题应该属于javascript类,你这样提问会导致知道分类分到php里去了。
实际上应该是前端控制的,有人说了,可以用jquery的$.post,如果你要用两个form, 那就不能用$('form')这种方式提交,因为会选到两个Form,可以分别加标示区分
<formid='good'>
</form>
<formid='bad'>
</form>
<script>
$('#good').submit();
</script>
而且点赞和踩,这种功能,不需要用到form, 两个Button就可以了