dedecms源碼分析之文章列表arclist_lib.php
時間: 2018-12-11 08:44
閱讀: 次
作者:素材無憂網(wǎng)
這個文件負責顯示文章的列表。
包括GetArclistCache(),lib_arclist(),lib_arclistDone(),lib_GetAutoChannelID(),list_sort_by()五個函數(shù)。
這五個函數(shù)的調(diào)用關系是
lib_arclist()->lib_GetAutoChannelID ;
lib_arclist()->lib_arclistDone();
lib_GetAutoChannelID ->GetArclistCache ();
lib_GetAutoChannelID ->list_sort_by();
整個文件中 lib_arclistDone()函數(shù)體的代碼最多最復雜,看起來很復雜,因為里面有很多的if語句。
lib_arclist()函數(shù)最先被調(diào)用,代碼比較少,主要是做一些基本參數(shù)的判斷和取值,為下面被調(diào)用的lib_arclistDone函數(shù)的形參列表做準備。這個函數(shù)里面有一個地方應該比較重要,可以決定什么時候調(diào)用什么模板。下面是代碼。
if(trim($ctag->GetInnerText()) != '')
$innertext = $ctag->GetInnerText();
else if($tagname=='imglist')
$innertext = GetSysTemplets('part_imglist.htm');
else if($tagname=='imginfolist')
$innertext = GetSysTemplets('part_imginfolist.htm');
else
$innertext = GetSysTemplets("part_arclist.htm");
GetSysTemplets()函數(shù)是其他地方的函數(shù),通過它可以獲得相應的模板。這里只需知道它的功能,不去研究它怎么來的和具體怎么實現(xiàn)的。
需要的參數(shù)準備就緒以后,就開始調(diào)用lib_arclistDone函數(shù)了,lib_arclistDone函數(shù)做了絕大部分工作,最重要的是根據(jù)傳進來的參數(shù)構成sql語句,然后使用dedesqli的 SetQuery,Execute方法從數(shù)據(jù)庫里面取數(shù)據(jù),然后根據(jù)調(diào)用的模板返回文章列表的字符串。這個文件也只有這個函數(shù)需要解釋的。
回到lib_arclist()調(diào)用lib_arclistDone()的地方。
lib_arclistDone
(
$refObj, $ctag, $typeid, $ctag->GetAtt('row'), $ctag->GetAtt('col'), $titlelen, $infolen,
$ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), $listtype, $orderby,
$ctag->GetAtt('keyword'), $innertext, $envs['aid'], $ctag->GetAtt('idlist'), $channelid,
$ctag->GetAtt('limit'), $flag,$ctag->GetAtt('orderway'), $ctag->GetAtt('subday'), $ctag->GetAtt('noflag'),
$tagid,$pagesize,$isweight
);
看到了吧,如此之多的參數(shù),每個參數(shù)的具體含義我就不說了,源碼注釋里面有。
lib_arclistDone函數(shù)對這些參數(shù)進行了處理,比如$titlelen = AttDef($titlelen,30)是將標題限制在30 以內(nèi);$innertext = trim($innertext)是將顯示文章列表的字符串去掉首尾空白。
接下來是設定sql語句的查詢條件和排序方式。
此處省略若干字,實在沒什么好講的。我們直接看查詢數(shù)據(jù)庫的sql語句是什么樣子
$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,
tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
$addfieldsSql
FROM `$maintable` arc LEFT JOIN `jcode_arctype` tp on arc.typeid=tp.id
$addfieldsSqlJoin
$orwhere $ordersql $limitsql";
其中maintable在這里一般是archives這個表
然后執(zhí)行這個sql語句:
$dsql->SetQuery($query);
$dsql->Execute('al');
到了lib_arclistDone的最后一個步驟了,就是講文章列表結(jié)果保存在$artlist里面,我們只是研究代碼的大概執(zhí)行過程,所以這里只抓住一條主線,那就是一般文章列表的顯示過程,artlist變量的賦值分為很多種情況,包括是否頁數(shù)大于0的情況,分兩欄顯示的情況等,一般情況下,直接跳到for($i=0; $i<$line; $i++)這個大循環(huán)里面。
找到
$liststr = $dtp2->GetResult();
$artlist .= $liststr."\r\n";
GetResult()返回一篇文章的信息,具體內(nèi)容跟你采用的模板有關。
到這一步,lib_arclistDone函數(shù)就基本結(jié)束了,后面的都是跟緩存什么的有關的。
標簽: