Dede系統經常被應用于各種網站搭建的內核部分。尤其是各種企業網站,圖片站最多,對于以上網站,有時候就需要結合頁面效果,從列表頁面展示圖集里頭的各種圖片。
織夢系統默認的圖集是不支持在列表頁內調用圖片,我們需要借助preg_match_all函數來讓dede可以支持一個新的標簽調用。
從include/common.func.php添加一個調用函數
//dede列表頁輸出多張圖片
function listimgs($aid, $imgwith = 500, $imgheight = 300, $num = 0, $style = ''){
global $dsql;
$imgurls = '';
$row = $dsql -> getone("Select imgurls From`dede_addonimages` where aid='$aid'"); //
$imgurls = $row['imgurls'];
preg_match_all("/{dede:img (.*)}(.*){\/dede:img/isU", $imgurls, $wordcount);
$count = count($wordcount[2]);
if ($num > $count || $num == 0){
$num = $count;
}
for($i = 0;$i < $num;$i++){
if($style == 'li'){
$imglist .= "<li><ahref=#" . $i . "><imgsrc=". trim($wordcount[2][$i]) . " width=" . $imgwith . " height=" . $imgheight . "></li></a>";
}else{
$imglist .= "<img src= " . trim($wordcount[2][$i]) . " width=" . $imgwith . "height=" . $imgheight . ">";
}
}
return $imglist;
}
保存后,在圖集列表頁{dede:list}之間使用[field:id function="listimgs(@me,100,100,9)" /],如:
{dede:list pagesize='25'}
[field:id function="listimgs(@me,70,100,9)" /]
{/dede:list}
如在其他地方調用該標簽,就用:{dede:field.id function="listimgs(@me,200,160,10)" /}
(@me,200,160,10)參數為,200寬度,160高度,圖片調用張數,末尾可以加上“,li”的參數,使圖片循環帶li標簽。