dedecms织梦点赞功能怎么做

首先后台执行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_IN
首先后台执行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 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 "赞过了.."; 
}
 
好了,点赞功能开发好了。有需要的朋友可以去试下!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

这篇文章给大家分享的是有关织梦dedecms调用当前栏目文章数的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。 做模板时,经常需要为每个栏目加上此栏目的文章数。和大家分享下实现的方法,此方法适合5.6及5.7、5.7sp1其它
现在许多网站使用了SSL技术,网站采用https链接,我们在复制https链接网站的内容,发现图片无法本地化,那么我们想要将这些图片本地化,要怎么操作呢? 第一步: 找到dede/inc/inc_archives_functions.php (注:前边红色的dede目录是您的后台目录) 定位到
最终实现效果如下图:内容生成之后会自动加上本篇文章的tags标签(文档生成时候自动加入,编辑器中内容实际没加入,更有利) 实现教程 1、后台-系统-核心设置-关键字替换,选择【是】 2、后台-系统-其他选项-关键词替换次数,填【1】或者【0】 1:表示文档内
我们传图集后需要对图片进行删除,但是系统提示已删除,实际还保存在网站目录里,这个要怎么解决呢? 打开 \dede\swfupload.php 找到 if(!file_exists($imgfile) !is_dir($imgfile) preg_match(#^.$cfg_medias_dir.#, $imgfile)) 替换成: if(file_exists($i
织梦tags标签只能写12个字符也就是6个汉字,多出的字符就会自动截断,或者直接被去除,不单单需要通过修改数据库字段长度,还要修改程序文件来改变tags字数限制,tags标签默认长度。 1、修改tags数据表字段长度 后台-系统-SQL命令行工具-执行下面2句语句(一起
大家都知道,Discuz程序在发文章时有个【隐藏】功能,可以限制这个隐藏内容供某些级别的会员查看。 在织梦模板中,做些改动,也是可以实现的。例如:电话号码,下载地址等等。 前提是开启会员功能,已经有了自定义字段。 一、建立文件 ajax_loginsta_c.php: