首先在/include/extend.func.php增加以下方法:
/** * 動態地址轉靜態輸出 by Windchaser QQ:939238564 * $arcurl 動態網址 * @return String */function arcurlHtml($arcurl){ preg_match('/view.php/?aid=(/d+)/',$arcurl,$arcid); if(!empty($arcid) && is_array($arcid)){//匹配是否存在動態地址 global $dsql; $addtable = $dsql->GetOne("SELECT channel.addtable FROM ym_channeltype AS channel LEFT JOIN ym_archives AS arc ON arc.channel=channel.idWHERE arc.id='{$arcid[1]}'");//獲取模型類型表名 $redirecturl = $dsql->GetOne("SELECT redirecturl FROM {$addtable['addtable']} WHERE aid = '{$arcid[1]}'");//動態獲取表名,并查詢redirecturl字段數據 if(!empty($redirecturl['redirecturl'])){ return $redirecturl['redirecturl'];//返回redirecturl字段數據 }else{ return $arcurl; } }else{//非動態地址直接返回原地址 return $arcurl; }}在模板上的使用方式有兩種形式:
#第一種:[field:arcurl function='arcurlHtml(@me)'/]#第二種:[field:id runphp='yes'] $id=@me;@me='';$url=GetOneArchive($id);@me=$url['arcurl'];@me=arcurlHtml(@me);[/field:id]
完整調用:
#第一種{dede:arclist titlelen='45' channelid='-1' limit='0,4' type='commend.' flag='c'} <li class="RTLi"><a href="[field:arcurl function='arcurlHtml(@me)'/]" {/dede:arclist}#第二種{dede:sql sql="SELECT * FROM xzzj_channeltype a left join xzzj_archives b on a.id = b.channel where a.id=-1 ORDER BY b.pubdate DESC LIMIT 0,2"} <a href="[field:id runphp='yes'] $id=@me;@me='';$url=GetOneArchive($id);@me=$url['arcurl'];@me=arcurlHtml(@me);[/field:id]" class="s_contentRTPIA" target="_blank" {/dede:sql}以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答