广告位联系
返回顶部
分享到

织梦dedecms二次开发独立点赞功能教程

网站程序 来源:互联网搜集 作者:酷站 发布时间:2018-08-05 17:22:21 人浏览
摘要

今天小编给大家分享织梦dedecms二次开发独立点赞功能教程 第一步: 在 dede_archives 表中增加zan 这个字段,用来记录每篇文章的赞数量 进入后台:系统--- SQL命令工具---输入以下sql语句,然后执行。(如果你的表前缀改了,记得修改dede_这个表前缀哦) ALT

今天小编给大家分享织梦dedecms二次开发独立点赞功能教程

第一步:在 dede_archives 表中增加 zan 这个字段,用来记录每篇文章的赞数量

 

进入后台:系统 ---> SQL命令工具  ---> 输入以下sql语句,然后执行。(如果你的表前缀改了,记得修改 dede_ 这个表前缀哦)
 

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

第二步:新建一个 dede_zan 表格,用来记录赞的具体数据,如点赞的文档aid,点赞人的ip,用ip可以判断是否重复点赞同一篇文章,执行sql语句如下:

   
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

 

第三步:写点赞函数,到  /include/ 的最下面,函数代码如下:
 

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

第四步:在模板上添加点赞按钮,css样式就自己写了,小编写一个简单的格式,分享如下:

<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.6.4/jquery.js"></script>
    <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; 
        }); 
    });
    </script>
    <div><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 www.lol9.cn织梦模板下载
    $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'; ");//写入赞数 
          
        $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 "赞过了.."; 
    }
    ?>

教程就这么多了,大家自己去试试吧。欢迎下方留言交流。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计