DedeCMS 列表頁調用文章的第一張圖片
來源:程序員人生 發布時間:2014-02-03 01:11:24 閱讀次數:3093次
1:有的幻燈片有大小圖,一般來說那大圖比小的要大很多,例如我仿制的163k的文章幻燈片就是如此,我看很多人都放棄了這個幻燈,因為顯示大圖的地方調用縮略圖的話就會圖片失真...
2:用來實現有些博客風格一個功能:在列表頁面每個日志的標題下顯示一張圖片(不是dede的縮略圖哦)
辦法,
由于標簽arclist不支持body,所以arclist調用的地方改為sql標簽 獨立模型列表和list支持底層模板調用body ,所以可以直接使用
{dede:sql sql='select * from dede_archives left join dede_addonarticle on dede_archives.id=dede_addonarticle.aid where find_in_set("f",dede_archives.flag)>0 order by dede_archives.id desc limit 0,5'}
<div>[field:body function=firstimg('@me')/]</div>
{/dede:sql}
注意:實現的辦法是自定義一個函數
函數代碼
Copy codefunction firstimg($str)
{
$str1 = str_replace('"','',$str);
preg_match('/<img[^>]*>/i',$str1,$str2);
$str3 = array_shift($str2);
$str4 = str_replace(' alt= ',' ',$str3);
return $str4;
}
將以上代碼加入到include下的channelunit.func.php中,
底層模板字段調用的時候
[field:body function=firstimg('@me')/]
標簽調用
{field:body function=firstimg('@me')/}
不過這個函數有它的局限性,文章中的圖片一定要出現在文章的開頭才能達到效果,否則會失敗
好了,辛苦了幾天終于搞定!
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈