Web_PHP_DedeCMS_点赞功能实现(客户端JQuery请求,服务端PHP响应)

一、后台准备

1、添加zan字段:dede_archives文章表添加zan字段;

ALTER TABLE dede_archives ADD zan int(11) NOT NULL DEFAULT '0' AFTER weight;

在 dede_archives 表中增加zan字段,这个字段被加到weight字段后边;


2、创建dede_zan赞数据表:保存被赞的文档aid 及IP的,为了检测是否赞过的IP;

CREATE TABLE IF NOT EXISTS `dede_zan` ( 
  `id` int(11) NOT NULL AUTO_INCREMENT, 
  `aid` int(11) NOT NULL, 
  `ip` varchar(40) NOT NULL, 
  PRIMARY KEY (`id`) 
) ENGINE=MyISAM  DEFAULT CHARSET=utf8

3、添加赞专属处理函数:在include/extend.func.php 中增加以下函数,用来获取文档被赞次数的,可以通过为文章id调用此函数来实现

function zan($aid) {
    global $dsql;
    $row = $dsql - > GetOne("Select id,zan From dede_archives where id='".$aid."'");
    return $row['zan'];<span style="white-space:pre">	</span>// 基于id从数据库中取出数据来显示;
}

二、前台实现(模板templets/default/article_article.htm)

1、HTML

<div class="zan">
    <p>
  		<!--此处rel属性用于保存文章ID号,以便用作请求参数-->
  		<a href="#" title="点赞 " class="img_on" rel="{dede:field.id/}">{dede:field.id function="zan(@me)"/}</a>
    </p>
</div>

2、CSS

<pre name="code" class="css">.zan p {
	background: #000;
	opacity: .8;
	filter: alpha(opacity=80);
}
.zan p a {
	padding-left: 30px;
	height: 24px;
	background: url(/images/heart.png) no-repeat 4px -1px;
	color: #fff;
	font-weight: bold;
	font-size: 14px
}
.zan p a:hover {
	background-position: 4px -25px;
	text-decoration: none
}

 3、加入JS,记得引入jquery.js; 

<script type="text/javascript" src="/jquery.js"></script>
$(function(){ 
    $("p a").click(function(){ 
        var zan = $(this); <span style="white-space:pre">	</span>// a链接;
        var id = zan.attr("rel"); //对应id;
 
        zan.fadeOut(300); //渐隐效果 
        $.ajax({ 
            type:"POST", 
            url:"/zan.php", 
            data:"id="+id, 
            cache:false, //不缓存此页面 
            success:function(data){ 
                zan.html(data); // 输出数据;
                zan.fadeIn(300); //渐显效果 
            } 
        }); 
        return false; 
    }); 
});

三、响应请求

1、建立zan.php 放到根目录

<?php
require_once (dirname(__FILE__) . "/include/common.inc.php");
$ip =getip(); //获取用户IP;
$id = $_POST['id']; 

if(!isset($id) || empty($id)) exit; 
 
//查询已赞过的IP
$dsql->SetQuery("SELECT ip FROM dede_zan  WHERE aid='".$id."' and ip='$ip'");
$dsql->Execute();
$count = $dsql->GetTotalRow();
 
if($count==0){ //如果没有记录 
 
    $dsql->ExecuteNoneQuery("update dede_archives set zan=zan+1 where id='$id'; ");//写入赞数
     
    $dsql->ExecuteNoneQuery("insert into dede_zan (aid,ip) values ('$id','$ip'); ");//写入IP,及被赞的AID 
 
    $rows = $dsql->GetOne("Select zan  from dede_archives where id='".$id."'");//获取被赞的数量
    $zan = $rows['zan']; //获取赞数值 
    echo $zan; <span style="white-space:pre">	</span>// 把数据返回客户端;
}else{ 
    echo "已赞"; 
}

特别说明:本文整理自http://jjm.hk/php_mysql/1121M2014.html,欢迎大家支持原版!







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值