一、首先备份数据库,然后执行SQL命令

系统》数据库命令

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

继续

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
 

二、打开文章模板

在自己需要的位置加入 

 <div  class="zan-num m-doc-qq-xx-zan" dir="{dede:field.id/}"><i class="iconfont icon-dianzan"></i><br /><span data-role="like" class="zan-size">{dede:field.id function="zan(@me)"/}</span> </div>

核心代码为最大层加class为zan-num 控制点击,dir 控制文章ID   ,zan-size控制点赞成功的数字

底部加入脚本,需要引入jq

<script language="javascript" type="text/javascript">

$(function(){  

    $(".zan-num").click(function(){  

        var zan = $(this); 

        var id = zan.attr("dir"); //对应id  

       // zan.find("i").fadeOut(300); //渐隐效果  

        $.ajax({  

            type:"POST",  

            url:"/zan.php",  

            data:"id="+id,  

            cache:false, //不缓存此页面  

            success:function(data){  

                zan.find(".zan-size").html(data);  

                zan.css("background-color","#f88120").fadeIn(300); //渐显效果  

            }  

        });  

        return false;  

    });  

}); 

</script>

 

三、在/include/extend.func.php 最后加入函数zan

function zan($aid) 

    global $dsql; 

    $row = $dsql->GetOne("Select id,zan From dede_archives where id='".$aid."'"); 

    return $row['zan']; 

    }

 

四、最后在根目录加入加入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;  

}else{  

    echo "赞过了..";  

}