国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > CMS > 織夢(mèng)DEDE > 正文

織夢(mèng)文章頁(yè)實(shí)現(xiàn)點(diǎn)贊功能(非插件)

2024-07-12 09:01:52
字體:
供稿:網(wǎng)友

因?yàn)樽约旱木W(wǎng)站是DedeCMS架構(gòu)的,實(shí)現(xiàn)起來比WordPress博客要復(fù)雜一些,武林網(wǎng)參考了一下DedeCMS自己帶的點(diǎn)贊功能,發(fā)現(xiàn)已經(jīng)十分完善,武林網(wǎng)就直接借鑒過來加以擴(kuò)展,加了一個(gè)打賞的二維碼,實(shí)現(xiàn)了自己博客文章頁(yè)的點(diǎn)贊+打賞功能,效果如下圖:

image.png

接下來,武林網(wǎng)把具體實(shí)現(xiàn)的方法寫出來,希望能對(duì)大家有所幫助。

一、js引用

實(shí)現(xiàn)點(diǎn)贊功能需要引用系統(tǒng)已有的js文件,這個(gè)文件位置為:/include/dedeajax2.js ,引用代碼為:

<script language="javascript" type="text/javascript" src="{dede:global.cfg_cmsurl/}/include/dedeajax2.js"></script> 將這段代碼放在DedeCMS當(dāng)前使用主題文章頁(yè)模版的<head>部分即可。緩存點(diǎn)擊數(shù)和判斷當(dāng)前是否點(diǎn)擊過的判斷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("您已經(jīng)表決過,請(qǐng)不要重復(fù)點(diǎn)擊哦 !"); 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調(diào)用語(yǔ)句后面。

注:余斗使用的DedeCMS版本為V5.7 SP1正式版,而DedeCMSV5.5版本以后都自帶dedeajax2.js 這個(gè)文件。

二、點(diǎn)贊/踩html代碼

將以下代碼放入要顯示點(diǎn)贊和踩的位置(一般都是文章頁(yè)調(diào)用文章正文代碼{dede:field.body /}后)


<!-- //頂踩 -->
  <div class="social-main" id="newdigg"></div>
    <script language="javascript" type="text/javascript">getDigg({dede:field.id/});</script>
    <!-- //頂踩部份的源碼結(jié)束 -->
 

三、css樣式

將以下css代碼加入到文章頁(yè)模版的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; }
 

實(shí)現(xiàn)的效果為:

image.png

樣式

 

image.png

打賞

 

四、提示語(yǔ)與html修改

點(diǎn)贊后提示語(yǔ)修改在第一步的第二段js代碼中,自己找到相關(guān)的文字,修改即可。

而調(diào)用點(diǎn)贊的html代碼中其實(shí)只有一段js而已,要修改點(diǎn)贊的相關(guān)html代碼則要打開/plus/digg_ajax.php,找到第98行,武林網(wǎng)這里的代碼為:

 

$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>';}


 

 

大家可以看到其實(shí)就是用js調(diào)用php文件中的這段html代碼實(shí)現(xiàn)的點(diǎn)贊和踩的計(jì)數(shù)功能,到這里就完美實(shí)現(xiàn)了DedeCMS文章頁(yè)實(shí)現(xiàn)點(diǎn)贊功能,而打賞功能中,圖片引用位置為/templets/yq/images/ds.png,大家可以把自己的打賞二維碼上傳到對(duì)應(yīng)文件夾做下名字的修改即可。

 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 政和县| 永吉县| 饶河县| 馆陶县| 邵武市| 新兴县| 巴林右旗| 三亚市| 卓尼县| 锡林郭勒盟| 阜新市| 荆门市| 江山市| 姜堰市| 蚌埠市| 安丘市| 伊川县| 申扎县| 邯郸县| 宕昌县| 台中县| 大关县| 吉安县| 修文县| 翼城县| 雷山县| 崇明县| 米易县| 太谷县| 开封县| 县级市| 新竹市| 镶黄旗| 阜宁县| 石狮市| 慈溪市| 晋州市| 鹤山市| 临漳县| 尖扎县| 峡江县|