織夢可以說是許多建站朋友的首選,用來做企業站、博客、商品站等等,最近有朋友想用織夢開發一個有點贊功能的網站,并且按點贊數量做成一個排行榜。那么這個dedecms點贊功能該怎么做呢?這個排行榜如何實現呢?我們一起來看一下。
首先,我們需要在織夢數據庫里 dede_archives 表中增加 zan 這個字段,加到weight這個字段后邊。
執行以下SQL語句即可:
ALTER TABLE dede_archives ADD zan int(11) NOT NULL DEFAULT ‘0’ AFTER weight;
然后執行以下SQL語句,新增名為dede_zan的表,這個表是保存被贊的文檔aid 及IP的,為了檢測是否贊過的IP。
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/extend.func.php 中增加以下函數,通過文章id獲取該文檔被贊次數的
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(這是dedecms默認的文章模板頁,如果更換了模板文件或名稱請自行查找)
加入CSS代碼,或者可以把下列代碼添加到css文件,引用進來,也可以自行設計該點贊圖標的樣式。
<style>
.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}
</style>
將下列JS代碼寫入獨立的js文件,名為zan.js
$(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;
});
});
引用jquary.js和zan.js
<script type=”text/javascript” src=”/jquery.js”></script>
<script type=”text/javascript” src=”/zan.js”></script>
在文章需要顯示點贊的位置加入以下代碼。
<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點贊功能就做好了。
下面就要講dedecms如何利用文章點贊數對文章進行排序了。
找到dede:arclist標簽源文件-include aglibrclist.lib.php
在arclist.lib.php文件查找“//文檔排序的方式”
第335行左右添加以下代碼
else if($orderby == ‘zan’) $ordersql = ” ORDER BY addf.zan $orderWay”;
其中addf是新字段附加表的sql別名。
然后找到dede:list標簽源文件-includerc.listview.class.php
在arc.listview.class.php頁面查找“//排序方式”
大概738行添加代碼
else if($orderby==”zan”) { $ordersql = ” ORDER BY addf.zan $orderWay”; }
查找“//獲得附加表的相關信息”
大概749行修改代碼,加“//”的是原代碼,”\”是修改的代碼(下同)
//$addJoin = ” LEFT JOIN `$addtable` ON arc.id = “.$addtable.’.aid ‘;
\$addJoin = ” LEFT JOIN `$addtable` addf ON arc.id = addf.aid “;
大概763行,修改if..else…中的代碼
if(!empty($arr[‘rename’])) {
//$addField .= ‘,’.$addtable.’.’.$k.’ as ‘.$arr[‘rename’];
\$addField .= ‘,addf.’.$k.’ as ‘.$arr[‘rename’];
} else {
// $addField .= ‘,’.$addtable.’.’.$k;
\$addField .= ‘,addf.’.$k; }
查找“//如果不用默認的sortrank或id排序,使用聯合查詢(數據量大時非常緩慢)”
大概763行,修改代碼
//if(preg_match(‘/hot|click|lastpost/’, $orderby))
\if(preg_match(‘/hot|click|lastpost|zan/’, $orderby))
最后,我們就可以用以下代碼按織夢點贊數對文章進行排序輸出了
{dede:arclist row=10 orderby=zan typeid=’1′}
<li><a href=”[field:arcurl/]”>[field:title/]</a></li>
{/dede:arclist}