DEDE

dede简单点赞功能开发实例

作者:本站 2017-07-05 浏览:234 标签: dede    点赞    

首先后台执行SQLALTER TABLE dede_archives ADD zan int(11) NOT NULL DEFAULT '0&

首先后台执行SQL

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

也就是在 dede_archives 表中增加 zan  这个字段,加到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

这个表是保存被赞的文档aid 及IP的,为了检测是否赞过的IP 

然后在include/extend.func.php 中增加以下函数,用来获取文档被赞次数的

function zan($aid) {     global $dsql;     $row = $dsql->GetOne("Select id,zan From dede_archives where id='".$aid."'");     return $row['zan'];     }

打开模板templets/default/article_article.htm加入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}

加入JS,记得引入jquery.js

<script type="text/javascript" src="/jquery.js"></script>

$(function(){      $("p a").click(function(){          var zan = $(this);          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;      });  });

加入

<div class="zan"><p><a href="#" title="赞一个 "class="img_on" rel="{dede:field.id/}">{dede:field.id function="zan(@me)"/}</a></p></div>

建立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 zanzan=zan+1 where id='$id'; ");    //写入IP,及被赞的AID       $dsql->ExecuteNoneQuery("insert into dede_zan (aid,ip) values ('$id','$ip'); ");    //获取被赞的数量     $rows = $dsql->GetOne("Select zan  from dede_archives where id='".$id."'");    $zan = $rows['zan']; //获取赞数值      echo $zan;  }else{      echo "赞过了..";  }

好了,点赞功能开发好了。


  • 0

  • 0

  • 1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.如有文章有版权争议,请给我们留言或者邮件告知我们,邮箱地址:028mw@126.com。