欢迎来到六久阁织梦模板网!
织梦文章页实现点赞功能(非插件)

织梦文章页实现点赞功能(非插件)

浏览次数: 0

作者: 六久阁织梦模板网

信息来源: 六久阁

更新日期: 2019-08-16

文章简介

因为自己的网站是DedeCMS架构的,实现起来比WordPress博客要复杂一些,六久阁参考了一下DedeCMS自己带的点赞功能,发现已经十分完善,六久阁就直接借鉴过来加以扩展,加了一个打赏的二维码,实现了自己博客文章页的点赞+打赏功能,效果如下图: 接下来,六久

  • 正文开始
  • 热门文章

    因为自己的网站是DedeCMS架构的,实现起来比WordPress博客要复杂一些,六久阁参考了一下DedeCMS自己带的点赞功能,发现已经十分完善,六久阁就直接借鉴过来加以扩展,加了一个打赏的二维码,实现了自己博客文章页的点赞+打赏功能,效果如下图:

    织梦文章页实现点赞功能(非插件)

    接下来,六久阁把具体实现的方法写出来,希望能对大家有所帮助。


    一、js引用

    实现点赞功能需要引用系统已有的js文件,这个文件位置为:/include/dedeajax2.js ,引用代码为:

    <script language="javascript" type="text/javascript" src="{dede:global.cfg_cmsurl/}/include/dedeajax2.js"></script>

    将这段代码放在DedeCMS当前使用主题文章页模版的<head>部分即可。缓存点击数和判断当前是否点击过的判断js代码为:

    <script language="javascript" type="text/javascript">
    <!--
    function postBadGood(ftype,fid)
    {
        var taget_obj = document.getElementById(ftype+fid);
        var saveid = GetCookie('badgoodid');
        if(saveid != null)
        {
            var saveids = saveid.split(',');
            var hasid = false;
            saveid = '';
            j = 1;
            for(i=saveids.length-1;i>=0;i--)
            {
                if(saveids[i]==fid && hasid) continue;
                else {
                    if(saveids[i]==fid && !hasid) hasid = true;
                    saveid += (saveid=='' ? saveids[i] : ','+saveids[i]);
                    j++;
                    if(j==10 && hasid) break;
                    if(j==9 && !hasid) break;
                }
            }
            if(hasid) { alert('您刚才已表决过了喔!'); return false;}
            else saveid += ','+fid;
            SetCookie('badgoodid',saveid,1);
        }
        else
        {
            SetCookie('badgoodid',fid,1);
        }
        myajax = new DedeAjax(taget_obj,false,false,'','','');
        myajax.SendGet2("{dede:field name='phpurl'/}/feedback.php?aid="+fid+"&action="+ftype+"&fid="+fid);
    }
    function postDigg(ftype,aid)
    {
        var taget_obj = document.getElementById('newdigg');
        var saveid = GetCookie('diggid');
        if(saveid != null)
        {
            var saveids = saveid.split(',');
            var hasid = false;
            saveid = '';
            j = 1;
            for(i=saveids.length-1;i>=0;i--)
            {
                if(saveids[i]==aid && hasid) continue;
                else {
                    if(saveids[i]==aid && !hasid) hasid = true;
                    saveid += (saveid=='' ? saveids[i] : ','+saveids[i]);
                    j++;
                    if(j==20 && hasid) break;
                    if(j==19 && !hasid) break;
                }
            }
            if(hasid) { alert("您已经表决过,请不要重复点击哦 !"); return; }
            else saveid += ','+aid;
            SetCookie('diggid',saveid,1);
        }
        else
        {
            SetCookie('diggid',aid,1);
        }
        myajax = new DedeAjax(taget_obj,false,false,'','','');
        var url = "{dede:global.cfg_phpurl/}/digg_ajax.php?action="+ftype+"&id="+aid;
        myajax.SendGet2(url);
    }
    function getDigg(aid)
    {
        var taget_obj = document.getElementById('newdigg');
        myajax = new DedeAjax(taget_obj,false,false,'','','');
        myajax.SendGet2("{dede:global.cfg_phpurl/}/digg_ajax.php?id="+aid);
        DedeXHTTP = null;
    }
    -->
    </script>

    这段代码紧跟dedeajax2.js调用语句后面。

    注:使用的DedeCMS版本为V5.7 SP1正式版,而DedeCMSV5.5版本以后都自带dedeajax2.js 这个文件。


    二、点赞/踩html代码

    将以下代码放入要显示点赞和踩的位置(一般都是文章页调用文章正文代码{dede:field.body /}后)

    <!-- //顶踩 -->

      <div class="social-main" id="newdigg"></div>

        <script language="javascript" type="text/javascript">getDigg({dede:field.id/});</script>

        <!-- //顶踩部份的源码结束 -->


    三、css样式

    将以下css代码加入到文章页模版的css文件中:

    /*顶踩*/
    #newdigg{border-bottom:medium none;padding:5px 0;}
    .social-main{margin:10px auto;position:relative;width:283px;height:40px}
    .social-main a{border-radius:2px;color:#fff;float:left;line-height:35px;text-align:center}
    .social-main a:hover{background:#878787 none repeat scroll 0 0;transition:all .2s ease-in 0s}
    .like a{background:#e15782 none repeat scroll 0 0;display:block;width:140px}
    .shang a{background:#5ea51b none repeat scroll 0 0;border:4px solid #fff;border-radius:40px;font-size:18px;font-weight:600;height:50px;left:115px;line-height:45px;position:absolute;top:-7px;width:50px}
    .bad a{background:#37ccca none repeat scroll 0 0;display:block;width:140px}
    .cpa{padding-left:10px;}
    .shang a:hover .s_in ,.shang a:hover .s_arrow ,.shang a:hover .s_img{display:block;}
    .s_img{display:none;position:relative;background:#fff none repeat scroll 0 0;border-radius:5px;border: 1px solid #ddd;padding: 10px 10px 2px;width: 246px;top:18px;right:113px;}
    .s_arrow {display:none;position: absolute; right:10px;top:35px; width: 0; height: 0; font-size: 0; border-width:16px; border-style: dashed dashed solid dashed; border-color: transparent transparent #ddd transparent;}
    .s_in{ display:none;position:absolute;right:-16px;top:-14px; width: 0; height: 0; font-size: 0; border-width:16px;border-color:transparent transparent #fff transparent; border-style:dashed dashed solid dashed; z-index:999; }

    实现的效果为:

    image.png


    四、提示语与html修改

    点赞后提示语修改在第一步的第二段js代码中,自己找到相关的文字,修改即可。

    而调用点赞的html代码中其实只有一段js而已,要修改点赞的相关html代码则要打开/plus/digg_ajax.php,找到第98行,六久阁这里的代码为:

    $digg = '<span class="like"><a href="javascript:;" onclick="postDigg(\'good\','.$id.')">顶一下
                            <span class="digg_num">('.$row['goodpost'].')</span> </a></span>
                <span class="shang"><a href="javascript:;" id="shang">赏<span class="s_arrow"><span class="s_in"></span></span><div class="s_img"><img src="/templets/yq/images/ds.png"></div></a></span>
                    <span class="bad"><a href="javascript:;" onclick="postDigg(\'bad\','.$id.')"><span class="cpa">踩一下<span class="digg_num">('.$row['badpost'].')</span></span></a></span>';
    }

    大家可以看到其实就是用js调用php文件中的这段html代码实现的点赞和踩的计数功能,到这里就完美实现了DedeCMS文章页实现点赞功能,而打赏功能中,图片引用位置为/templets/yq/images/ds.png,大家可以把自己的打赏二维码上传到对应文件夹做下名字的修改即可。

织梦二次开发QQ群

本站客服QQ号:862782808(点击左边QQ号交流),群号(383578617) DedeCMS织梦教程QQ群 如果您有任何织梦问题,请把问题发到群里,阁主将为您写解决教程!

转载请注明: 织梦模板 » 织梦文章页实现点赞功能(非插件)

  • 织梦dedecms手机站m目录下不生成index.html实现动态更新
    阅读
    用 织梦建站 会手机站首页不更新的苦恼,每次 PC 更新,要去删除 m 目录下的 index.html ,手机站首页才会更新,这样很麻烦,通过以下修改,让手机站首页是动态的,不生成 index.html , PC 端更新后,手机端首页自动更新。 把 \m\index.php 里面的 $row[sho...
  • 织梦Fatal error: Call to undefined function make_hash() in /dede/sys_info.php on line 201的解决方法
    阅读
    织梦系统安装好后,进入后台,出现Fatal error: Call to undefined function make_hash() in /dede/sys_info.php on line 201 一般出现这个问题是因为升级网站引起的。我们可以直接把错误提示这段代码删除或者屏蔽就行了。 打开/dede/sys_info.php,找到201...
  • 织梦Dedecms 5.7 火车头采集免登陆发布接口适配PHP7.X插件
    阅读
    最近有粉丝说,之前用的火车头发布文章时,用免登陆接口在PHP7.0环境中显示空白,于是今天抽空更新了一下插件(话说,DedeCms早期版本无法在PHP7.X运行,用最新版的!),那么接下来的代码就是插件发布模块无须变更,只需要变更接口插件就可以了 ?php/*/////...
  • 织梦dedecms系统多城市分站功能开发思路
    阅读
    当前很多人用织梦dedecms系统建站,多城市分站对地方性长尾关键词和全国市场的推广有着很大的帮助,今天和大家分享下如何实现织梦dedecms系统多城市分站功能。 方法/步骤 织梦dede城市分站有三种方法: 第一种是建立N多个模板,有多少个城市建立多少个模板,...
  • 织梦dedecms提交自定义表单后发送到指定邮箱
    阅读
    网上很多教程都是用 dedecms 自带的邮件库发送邮件,而且是写死要发送的字段内容,今天我们用 phpmailer 来给站长发送自定义表单提交的数据到指定邮箱上 (QQ 邮箱, 163 邮箱都可以 ) ,不写死任何东西,有什么字段就提交发送什么字段。 操作之前,我们要先...
  • 织梦5.7火车头免登陆文章发布模块采集后自动更新织梦整站
    阅读
    织梦5.7火车头免登陆文章发布模块采集后自动更新织梦整站详细步骤: 1、下载文档后,把DedeCMS免登陆接口文章发布模块DedeCMS 5.7 免登陆接口文章发布模块.wpm复制到火车头采集规则文件夹Module下; 2、选择您网站对应的接口文件.如您网站是gbk编码,请选择 g...
  • dedecms织梦ckplayer视频播放器插件详细安装教程
    阅读
    织梦 ckplayer 视频播放器插件安装步骤: 第一步、下载安装插件。下载地址:点击此处 将下载下来的压缩包中的相应编码的模块文件解压出来再上传到织梦程序的 data/module/ 文件夹内或者直接在后台模块管理菜单里面选择上传新模块安装即可。如下图: 1.1 )上...
  • 织梦采集侠破解版自动采集触发教程24小时触发自动审核自动更新
    阅读
    最新采集侠V2.9.2破解版,可以在网站进行全自动数据采集,采集侠破解版可以帮助用户快速提升自己网站的Seo排名。 织梦采集侠是一款基于dedecms的一套根据关键词自动采集,无须编写复杂的采集规则,自动伪原创,自动发布内容的绿色插件。简单配置好后能实现24...
  • 织梦dedecms网站添加打赏功能
    阅读
    有时我们看到别人家的织梦dedecms网站有打赏功能,是不是羡慕嫉妒恨呢?今天我来给大家讲讲织梦网站怎么添加支付宝、微信打赏功能。 二、首先登陆畅言后台(没有畅言账号的首先注册账号) 三、进入后台,找到实验室--打赏 四、设置配置信息,保存。 五、复制...
  • 织梦火车头采集免登陆接口采集文章后自动更新栏目、首页、文章页,实现自动化采集
    阅读
    最近用织梦dedecms程序采集文章时候,发现每次采集都要去后台更新一下文章、栏目、上下篇以及首页,操作起来真心麻烦,后面在网上收集了一些代码以及经过自己调试,发现居然可以自动更新文章页以及栏目、首页。真心爽,这样子就能稳稳的挂机采集了哈。这是免...
收藏此文 打赏本站

如本文对您有帮助,就请六久阁织梦模板网抽根烟吧!

  • 支付宝打赏
    支付宝扫描打赏
    微信打赏
    微信扫描打赏
织梦后台系统设置在PHP5.4环境中不能保存中文参数的解决方法
« 上一篇 2018年04月12日
织梦有子栏目则调用子栏目,没有子栏目则输出空
下一篇 » 2018年04月12日

精彩评论

有问题在这里提问,阁主会为你解决!
  • 全部评论(0
    还没有评论,快来抢沙发吧!
  • 评论
推荐织梦插件更多
更新时间:2019-02-01

人已经看过了!

更新时间:2019-01-01

人已经看过了!

更新时间:2018-06-02

人已经看过了!

更新时间:2017-09-11

人已经看过了!

更新时间:2019-04-07

人已经看过了!

更新时间:2019-10-11

人已经看过了!

推荐精品模板更多
高端品牌建筑装饰类响应式织梦模板
更新时间:2017-08-10

人已经看过了!

大气红色地方门户新闻文章资讯dedecms模板(带手机端)
更新时间:2019-11-08

人已经看过了!

橙黄色机械设备企业营销型织梦模板+测试数据
更新时间:2021-10-21

人已经看过了!

房地产房屋建筑建造装修类织梦模板(带手机端)
更新时间:2019-11-11

人已经看过了!

漂亮清爽的织梦会员中心模板带推广邀请发布文章
更新时间:2021-10-21

人已经看过了!

营销型绿色塑料制品类织梦模板(带手机端)
更新时间:2019-11-10

人已经看过了!

现代简约HTML5自适应家装设计类织梦模板
更新时间:2018-04-17

人已经看过了!